@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,167 +1,478 @@
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
+ import { assertNotEqual } from '../assert';
6
+ import { EMPTY_ARRAY, EMPTY_OBJ } from '../empty';
5
7
  import { RendererStyleFlags3, isProceduralRenderer } from '../interfaces/renderer';
6
8
  import { NO_CHANGE } from '../tokens';
7
9
  import { getRootContext } from '../util';
8
10
  import { BoundPlayerFactory } from './player_factory';
9
11
  import { addPlayerInternal, allocPlayerContext, createEmptyStylingContext, getPlayerContext } from './util';
10
- /** @type {?} */
11
- const EMPTY_ARR = [];
12
- /** @type {?} */
13
- const EMPTY_OBJ = {};
14
- /**
15
- * Creates a styling context template where styling information is stored.
16
- * Any styles that are later referenced using `updateStyleProp` must be
17
- * passed in within this function. Initial values for those styles are to
18
- * be declared after all initial style properties are declared (this change in
19
- * mode between declarations and initial styles is made possible using a special
20
- * enum value found in `definition.ts`).
21
- *
22
- * @param {?=} initialClassDeclarations a list of class declarations and initial class values
23
- * that are used later within the styling context.
24
- *
25
- * -> ['foo', 'bar', SPECIAL_ENUM_VAL, 'foo', true]
26
- * This implies that `foo` and `bar` will be later styled and that the `foo`
27
- * class will be applied to the element as an initial class since it's true
28
- * @param {?=} initialStyleDeclarations a list of style declarations and initial style values
29
- * that are used later within the styling context.
12
+ /**
13
+ * This file includes the code to power all styling-binding operations in Angular.
30
14
  *
31
- * -> ['width', 'height', SPECIAL_ENUM_VAL, 'width', '100px']
32
- * This implies that `width` and `height` will be later styled and that the `width`
33
- * property has an initial value of `100px`.
15
+ * These include:
16
+ * [style]="myStyleObj"
17
+ * [class]="myClassObj"
18
+ * [style.prop]="myPropValue"
19
+ * [class.name]="myClassValue"
34
20
  *
35
- * @param {?=} styleSanitizer
36
- * @param {?=} onlyProcessSingleClasses
21
+ * There are many different ways in which these functions below are called. Please see
22
+ * `interfaces/styles.ts` to get a better idea of how the styling algorithm works.
23
+ */
24
+ /**
25
+ * Creates a new StylingContext an fills it with the provided static styling attribute values.
26
+ * @param {?} attrs
37
27
  * @return {?}
38
28
  */
39
- export function createStylingContextTemplate(initialClassDeclarations, initialStyleDeclarations, styleSanitizer, onlyProcessSingleClasses) {
40
- /** @type {?} */
41
- const initialStylingValues = [null];
29
+ export function initializeStaticContext(attrs) {
42
30
  /** @type {?} */
43
- const context = createEmptyStylingContext(null, styleSanitizer, initialStylingValues);
31
+ const context = createEmptyStylingContext();
44
32
  /** @type {?} */
45
- const stylesLookup = {};
33
+ const initialClasses = context[3 /* InitialClassValuesPosition */] =
34
+ [null];
46
35
  /** @type {?} */
47
- const classesLookup = {};
36
+ const initialStyles = context[2 /* InitialStyleValuesPosition */] =
37
+ [null];
38
+ // The attributes array has marker values (numbers) indicating what the subsequent
39
+ // values represent. When we encounter a number, we set the mode to that type of attribute.
48
40
  /** @type {?} */
49
- let totalStyleDeclarations = 0;
50
- if (initialStyleDeclarations) {
41
+ let mode = -1;
42
+ for (let i = 0; i < attrs.length; i++) {
51
43
  /** @type {?} */
52
- let hasPassedDeclarations = false;
53
- for (let i = 0; i < initialStyleDeclarations.length; i++) {
44
+ const attr = attrs[i];
45
+ if (typeof attr == 'number') {
46
+ mode = attr;
47
+ }
48
+ else if (mode === 2 /* Styles */) {
49
+ initialStyles.push((/** @type {?} */ (attr)), (/** @type {?} */ (attrs[++i])));
50
+ }
51
+ else if (mode === 1 /* Classes */) {
52
+ initialClasses.push((/** @type {?} */ (attr)), true);
53
+ }
54
+ else if (mode === 3 /* SelectOnly */) {
55
+ break;
56
+ }
57
+ }
58
+ return context;
59
+ }
60
+ /**
61
+ * Designed to update an existing styling context with new static styling
62
+ * data (classes and styles).
63
+ *
64
+ * @param {?} context the existing styling context
65
+ * @param {?} attrs an array of new static styling attributes that will be
66
+ * assigned to the context
67
+ * @param {?} directive the directive instance with which static data is associated with.
68
+ * @return {?}
69
+ */
70
+ export function patchContextWithStaticAttrs(context, attrs, directive) {
71
+ // If the styling context has already been patched with the given directive's bindings,
72
+ // then there is no point in doing it again. The reason why this may happen (the directive
73
+ // styling being patched twice) is because the `stylingBinding` function is called each time
74
+ // an element is created (both within a template function and within directive host bindings).
75
+ /** @type {?} */
76
+ const directives = context[1 /* DirectiveRegistryPosition */];
77
+ if (getDirectiveRegistryValuesIndexOf(directives, directive) == -1) {
78
+ // this is a new directive which we have not seen yet.
79
+ directives.push(directive, -1, false, null);
80
+ /** @type {?} */
81
+ let initialClasses = null;
82
+ /** @type {?} */
83
+ let initialStyles = null;
84
+ /** @type {?} */
85
+ let mode = -1;
86
+ for (let i = 0; i < attrs.length; i++) {
54
87
  /** @type {?} */
55
- const v = /** @type {?} */ (initialStyleDeclarations[i]);
56
- // this flag value marks where the declarations end the initial values begin
57
- if (v === 1 /* VALUES_MODE */) {
58
- hasPassedDeclarations = true;
88
+ const attr = attrs[i];
89
+ if (typeof attr == 'number') {
90
+ mode = attr;
59
91
  }
60
- else {
61
- /** @type {?} */
62
- const prop = /** @type {?} */ (v);
63
- if (hasPassedDeclarations) {
64
- /** @type {?} */
65
- const value = /** @type {?} */ (initialStyleDeclarations[++i]);
66
- initialStylingValues.push(value);
67
- stylesLookup[prop] = initialStylingValues.length - 1;
68
- }
69
- else {
70
- totalStyleDeclarations++;
71
- stylesLookup[prop] = 0;
72
- }
92
+ else if (mode == 1 /* Classes */) {
93
+ initialClasses = initialClasses || context[3 /* InitialClassValuesPosition */];
94
+ patchInitialStylingValue(initialClasses, attr, true);
95
+ }
96
+ else if (mode == 2 /* Styles */) {
97
+ initialStyles = initialStyles || context[2 /* InitialStyleValuesPosition */];
98
+ patchInitialStylingValue(initialStyles, attr, attrs[++i]);
73
99
  }
74
100
  }
75
101
  }
76
- // make where the class offsets begin
77
- context[4 /* ClassOffsetPosition */] = totalStyleDeclarations;
78
- /** @type {?} */
79
- const initialStaticClasses = onlyProcessSingleClasses ? [] : null;
80
- if (initialClassDeclarations) {
102
+ }
103
+ /**
104
+ * Designed to add a style or class value into the existing set of initial styles.
105
+ *
106
+ * The function will search and figure out if a style/class value is already present
107
+ * within the provided initial styling array. If and when a style/class value is not
108
+ * present (or if it's value is falsy) then it will be inserted/updated in the list
109
+ * of initial styling values.
110
+ * @param {?} initialStyling
111
+ * @param {?} prop
112
+ * @param {?} value
113
+ * @return {?}
114
+ */
115
+ function patchInitialStylingValue(initialStyling, prop, value) {
116
+ // Even values are keys; Odd numbers are values; Search keys only
117
+ for (let i = 1 /* KeyValueStartPosition */; i < initialStyling.length;) {
81
118
  /** @type {?} */
82
- let hasPassedDeclarations = false;
83
- for (let i = 0; i < initialClassDeclarations.length; i++) {
119
+ const key = initialStyling[i];
120
+ if (key === prop) {
84
121
  /** @type {?} */
85
- const v = /** @type {?} */ (initialClassDeclarations[i]);
86
- // this flag value marks where the declarations end the initial values begin
87
- if (v === 1 /* VALUES_MODE */) {
88
- hasPassedDeclarations = true;
122
+ const existingValue = initialStyling[i + 1 /* ValueOffset */];
123
+ // If there is no previous style value (when `null`) or no previous class
124
+ // applied (when `false`) then we update the the newly given value.
125
+ if (existingValue == null || existingValue == false) {
126
+ initialStyling[i + 1 /* ValueOffset */] = value;
127
+ }
128
+ return;
129
+ }
130
+ i = i + 2 /* Size */;
131
+ }
132
+ // We did not find existing key, add a new one.
133
+ initialStyling.push(prop, value);
134
+ }
135
+ /**
136
+ * Runs through the initial styling data present in the context and renders
137
+ * them via the renderer on the element.
138
+ * @param {?} element
139
+ * @param {?} context
140
+ * @param {?} renderer
141
+ * @return {?}
142
+ */
143
+ export function renderInitialStylesAndClasses(element, context, renderer) {
144
+ /** @type {?} */
145
+ const initialClasses = context[3 /* InitialClassValuesPosition */];
146
+ renderInitialStylingValues(element, renderer, initialClasses, true);
147
+ /** @type {?} */
148
+ const initialStyles = context[2 /* InitialStyleValuesPosition */];
149
+ renderInitialStylingValues(element, renderer, initialStyles, false);
150
+ }
151
+ /**
152
+ * This is a helper function designed to render each entry present within the
153
+ * provided list of initialStylingValues.
154
+ * @param {?} element
155
+ * @param {?} renderer
156
+ * @param {?} initialStylingValues
157
+ * @param {?} isEntryClassBased
158
+ * @return {?}
159
+ */
160
+ function renderInitialStylingValues(element, renderer, initialStylingValues, isEntryClassBased) {
161
+ for (let i = 1 /* KeyValueStartPosition */; i < initialStylingValues.length; i += 2 /* Size */) {
162
+ /** @type {?} */
163
+ const value = initialStylingValues[i + 1 /* ValueOffset */];
164
+ if (value) {
165
+ if (isEntryClassBased) {
166
+ setClass(element, (/** @type {?} */ (initialStylingValues[i + 0 /* PropOffset */])), true, renderer, null);
89
167
  }
90
168
  else {
91
- /** @type {?} */
92
- const className = /** @type {?} */ (v);
93
- if (hasPassedDeclarations) {
94
- /** @type {?} */
95
- const value = /** @type {?} */ (initialClassDeclarations[++i]);
96
- initialStylingValues.push(value);
97
- classesLookup[className] = initialStylingValues.length - 1;
98
- initialStaticClasses && initialStaticClasses.push(className);
99
- }
100
- else {
101
- classesLookup[className] = 0;
102
- }
169
+ setStyle(element, (/** @type {?} */ (initialStylingValues[i + 0 /* PropOffset */])), (/** @type {?} */ (value)), renderer, null);
103
170
  }
104
171
  }
105
172
  }
173
+ }
174
+ /**
175
+ * @param {?} context
176
+ * @return {?}
177
+ */
178
+ export function allowNewBindingsForStylingContext(context) {
179
+ return (context[0 /* MasterFlagPosition */] & 32 /* BindingAllocationLocked */) === 0;
180
+ }
181
+ /**
182
+ * Adds in new binding values to a styling context.
183
+ *
184
+ * If a directive value is provided then all provided class/style binding names will
185
+ * reference the provided directive.
186
+ *
187
+ * @param {?} context the existing styling context
188
+ * @param {?} directiveRef the directive that the new bindings will reference
189
+ * @param {?=} classBindingNames an array of class binding names that will be added to the context
190
+ * @param {?=} styleBindingNames an array of style binding names that will be added to the context
191
+ * @param {?=} styleSanitizer an optional sanitizer that handle all sanitization on for each of
192
+ * the bindings added to the context. Note that if a directive is provided then the sanitizer
193
+ * instance will only be active if and when the directive updates the bindings that it owns.
194
+ * @param {?=} onlyProcessSingleClasses
195
+ * @return {?}
196
+ */
197
+ export function updateContextWithBindings(context, directiveRef, classBindingNames, styleBindingNames, styleSanitizer, onlyProcessSingleClasses) {
198
+ if (context[0 /* MasterFlagPosition */] & 32 /* BindingAllocationLocked */)
199
+ return;
200
+ // this means the context has already been patched with the directive's bindings
201
+ /** @type {?} */
202
+ const directiveIndex = findOrPatchDirectiveIntoRegistry(context, directiveRef, styleSanitizer);
203
+ if (directiveIndex === -1) {
204
+ // this means the directive has already been patched in ... No point in doing anything
205
+ return;
206
+ }
207
+ // there are alot of variables being used below to track where in the context the new
208
+ // binding values will be placed. Because the context consists of multiple types of
209
+ // entries (single classes/styles and multi classes/styles) alot of the index positions
210
+ // need to be computed ahead of time and the context needs to be extended before the values
211
+ // are inserted in.
212
+ /** @type {?} */
213
+ const singlePropOffsetValues = context[4 /* SinglePropOffsetPositions */];
214
+ /** @type {?} */
215
+ const totalCurrentClassBindings = singlePropOffsetValues[1 /* ClassesCountPosition */];
216
+ /** @type {?} */
217
+ const totalCurrentStyleBindings = singlePropOffsetValues[0 /* StylesCountPosition */];
106
218
  /** @type {?} */
107
- const styleProps = Object.keys(stylesLookup);
219
+ const classesOffset = totalCurrentClassBindings * 4 /* Size */;
108
220
  /** @type {?} */
109
- const classNames = Object.keys(classesLookup);
221
+ const stylesOffset = totalCurrentStyleBindings * 4 /* Size */;
110
222
  /** @type {?} */
111
- const classNamesIndexStart = styleProps.length;
223
+ const singleStylesStartIndex = 9 /* SingleStylesStartPosition */;
112
224
  /** @type {?} */
113
- const totalProps = styleProps.length + classNames.length;
225
+ let singleClassesStartIndex = singleStylesStartIndex + stylesOffset;
114
226
  /** @type {?} */
115
- const maxLength = totalProps * 4 /* Size */ * 2 + 8 /* SingleStylesStartPosition */;
116
- // we need to fill the array from the start so that we can access
117
- // both the multi and the single array positions in the same loop block
118
- for (let i = 8 /* SingleStylesStartPosition */; i < maxLength; i++) {
227
+ let multiStylesStartIndex = singleClassesStartIndex + classesOffset;
228
+ /** @type {?} */
229
+ let multiClassesStartIndex = multiStylesStartIndex + stylesOffset;
230
+ // because we're inserting more bindings into the context, this means that the
231
+ // binding values need to be referenced the singlePropOffsetValues array so that
232
+ // the template/directive can easily find them inside of the `elementStyleProp`
233
+ // and the `elementClassProp` functions without iterating through the entire context.
234
+ // The first step to setting up these reference points is to mark how many bindings
235
+ // are being added. Even if these bindings already exist in the context, the directive
236
+ // or template code will still call them unknowingly. Therefore the total values need
237
+ // to be registered so that we know how many bindings are assigned to each directive.
238
+ /** @type {?} */
239
+ const currentSinglePropsLength = singlePropOffsetValues.length;
240
+ singlePropOffsetValues.push(styleBindingNames ? styleBindingNames.length : 0, classBindingNames ? classBindingNames.length : 0);
241
+ // the code below will check to see if a new style binding already exists in the context
242
+ // if so then there is no point in inserting it into the context again. Whether or not it
243
+ // exists the styling offset code will now know exactly where it is
244
+ /** @type {?} */
245
+ let insertionOffset = 0;
246
+ /** @type {?} */
247
+ const filteredStyleBindingNames = [];
248
+ if (styleBindingNames && styleBindingNames.length) {
249
+ for (let i = 0; i < styleBindingNames.length; i++) {
250
+ /** @type {?} */
251
+ const name = styleBindingNames[i];
252
+ /** @type {?} */
253
+ let singlePropIndex = getMatchingBindingIndex(context, name, singleStylesStartIndex, singleClassesStartIndex);
254
+ if (singlePropIndex == -1) {
255
+ singlePropIndex = singleClassesStartIndex + insertionOffset;
256
+ insertionOffset += 4 /* Size */;
257
+ filteredStyleBindingNames.push(name);
258
+ }
259
+ singlePropOffsetValues.push(singlePropIndex);
260
+ }
261
+ }
262
+ // just like with the style binding loop above, the new class bindings get the same treatment...
263
+ /** @type {?} */
264
+ const filteredClassBindingNames = [];
265
+ if (classBindingNames && classBindingNames.length) {
266
+ for (let i = 0; i < classBindingNames.length; i++) {
267
+ /** @type {?} */
268
+ const name = classBindingNames[i];
269
+ /** @type {?} */
270
+ let singlePropIndex = getMatchingBindingIndex(context, name, singleClassesStartIndex, multiStylesStartIndex);
271
+ if (singlePropIndex == -1) {
272
+ singlePropIndex = multiStylesStartIndex + insertionOffset;
273
+ insertionOffset += 4 /* Size */;
274
+ filteredClassBindingNames.push(name);
275
+ }
276
+ else {
277
+ singlePropIndex += filteredStyleBindingNames.length * 4 /* Size */;
278
+ }
279
+ singlePropOffsetValues.push(singlePropIndex);
280
+ }
281
+ }
282
+ // because new styles are being inserted, this means the existing collection of style offset
283
+ // index values are incorrect (they point to the wrong values). The code below will run through
284
+ // the entire offset array and update the existing set of index values to point to their new
285
+ // locations while taking the new binding values into consideration.
286
+ /** @type {?} */
287
+ let i = 2 /* ValueStartPosition */;
288
+ if (filteredStyleBindingNames.length) {
289
+ while (i < currentSinglePropsLength) {
290
+ /** @type {?} */
291
+ const totalStyles = singlePropOffsetValues[i + 0 /* StylesCountPosition */];
292
+ /** @type {?} */
293
+ const totalClasses = singlePropOffsetValues[i + 1 /* ClassesCountPosition */];
294
+ if (totalClasses) {
295
+ /** @type {?} */
296
+ const start = i + 2 /* ValueStartPosition */ + totalStyles;
297
+ for (let j = start; j < start + totalClasses; j++) {
298
+ singlePropOffsetValues[j] += filteredStyleBindingNames.length * 4 /* Size */;
299
+ }
300
+ }
301
+ /** @type {?} */
302
+ const total = totalStyles + totalClasses;
303
+ i += 2 /* ValueStartPosition */ + total;
304
+ }
305
+ }
306
+ /** @type {?} */
307
+ const totalNewEntries = filteredClassBindingNames.length + filteredStyleBindingNames.length;
308
+ // in the event that there are new style values being inserted, all existing class and style
309
+ // bindings need to have their pointer values offsetted with the new amount of space that is
310
+ // used for the new style/class bindings.
311
+ for (let i = singleStylesStartIndex; i < context.length; i += 4 /* Size */) {
312
+ /** @type {?} */
313
+ const isMultiBased = i >= multiStylesStartIndex;
314
+ /** @type {?} */
315
+ const isClassBased = i >= (isMultiBased ? multiClassesStartIndex : singleClassesStartIndex);
316
+ /** @type {?} */
317
+ const flag = getPointers(context, i);
318
+ /** @type {?} */
319
+ const staticIndex = getInitialIndex(flag);
320
+ /** @type {?} */
321
+ let singleOrMultiIndex = getMultiOrSingleIndex(flag);
322
+ if (isMultiBased) {
323
+ singleOrMultiIndex +=
324
+ isClassBased ? (filteredStyleBindingNames.length * 4 /* Size */) : 0;
325
+ }
326
+ else {
327
+ singleOrMultiIndex += (totalNewEntries * 4 /* Size */) +
328
+ ((isClassBased ? filteredStyleBindingNames.length : 0) * 4 /* Size */);
329
+ }
330
+ setFlag(context, i, pointers(flag, staticIndex, singleOrMultiIndex));
331
+ }
332
+ // this is where we make space in the context for the new style bindings
333
+ for (let i = 0; i < filteredStyleBindingNames.length * 4 /* Size */; i++) {
334
+ context.splice(multiClassesStartIndex, 0, null);
335
+ context.splice(singleClassesStartIndex, 0, null);
336
+ singleClassesStartIndex++;
337
+ multiStylesStartIndex++;
338
+ multiClassesStartIndex += 2; // both single + multi slots were inserted
339
+ }
340
+ // this is where we make space in the context for the new class bindings
341
+ for (let i = 0; i < filteredClassBindingNames.length * 4 /* Size */; i++) {
342
+ context.splice(multiStylesStartIndex, 0, null);
119
343
  context.push(null);
344
+ multiStylesStartIndex++;
345
+ multiClassesStartIndex++;
120
346
  }
121
347
  /** @type {?} */
122
- const singleStart = 8 /* SingleStylesStartPosition */;
348
+ const initialClasses = context[3 /* InitialClassValuesPosition */];
123
349
  /** @type {?} */
124
- const multiStart = totalProps * 4 /* Size */ + 8 /* SingleStylesStartPosition */;
125
- // fill single and multi-level styles
126
- for (let i = 0; i < totalProps; i++) {
350
+ const initialStyles = context[2 /* InitialStyleValuesPosition */];
351
+ // the code below will insert each new entry into the context and assign the appropriate
352
+ // flags and index values to them. It's important this runs at the end of this function
353
+ // because the context, property offset and index values have all been computed just before.
354
+ for (let i = 0; i < totalNewEntries; i++) {
127
355
  /** @type {?} */
128
- const isClassBased = i >= classNamesIndexStart;
356
+ const entryIsClassBased = i >= filteredStyleBindingNames.length;
129
357
  /** @type {?} */
130
- const prop = isClassBased ? classNames[i - classNamesIndexStart] : styleProps[i];
358
+ const adjustedIndex = entryIsClassBased ? (i - filteredStyleBindingNames.length) : i;
131
359
  /** @type {?} */
132
- const indexForInitial = isClassBased ? classesLookup[prop] : stylesLookup[prop];
360
+ const propName = entryIsClassBased ? filteredClassBindingNames[adjustedIndex] :
361
+ filteredStyleBindingNames[adjustedIndex];
133
362
  /** @type {?} */
134
- const initialValue = initialStylingValues[indexForInitial];
363
+ let multiIndex;
135
364
  /** @type {?} */
136
- const indexForMulti = i * 4 /* Size */ + multiStart;
365
+ let singleIndex;
366
+ if (entryIsClassBased) {
367
+ multiIndex = multiClassesStartIndex +
368
+ ((totalCurrentClassBindings + adjustedIndex) * 4 /* Size */);
369
+ singleIndex = singleClassesStartIndex +
370
+ ((totalCurrentClassBindings + adjustedIndex) * 4 /* Size */);
371
+ }
372
+ else {
373
+ multiIndex =
374
+ multiStylesStartIndex + ((totalCurrentStyleBindings + adjustedIndex) * 4 /* Size */);
375
+ singleIndex = singleStylesStartIndex +
376
+ ((totalCurrentStyleBindings + adjustedIndex) * 4 /* Size */);
377
+ }
378
+ // if a property is not found in the initial style values list then it
379
+ // is ALWAYS added incase a follow-up directive introduces the same initial
380
+ // style/class value later on.
137
381
  /** @type {?} */
138
- const indexForSingle = i * 4 /* Size */ + singleStart;
382
+ let initialValuesToLookup = entryIsClassBased ? initialClasses : initialStyles;
139
383
  /** @type {?} */
140
- const initialFlag = prepareInitialFlag(prop, isClassBased, styleSanitizer || null);
141
- setFlag(context, indexForSingle, pointers(initialFlag, indexForInitial, indexForMulti));
142
- setProp(context, indexForSingle, prop);
143
- setValue(context, indexForSingle, null);
144
- setPlayerBuilderIndex(context, indexForSingle, 0);
384
+ let indexForInitial = getInitialStylingValuesIndexOf(initialValuesToLookup, propName);
385
+ if (indexForInitial === -1) {
386
+ indexForInitial = initialValuesToLookup.length + 1 /* ValueOffset */;
387
+ initialValuesToLookup.push(propName, entryIsClassBased ? false : null);
388
+ }
389
+ else {
390
+ indexForInitial += 1 /* ValueOffset */;
391
+ }
145
392
  /** @type {?} */
146
- const flagForMulti = initialFlag | (initialValue !== null ? 1 /* Dirty */ : 0 /* None */);
147
- setFlag(context, indexForMulti, pointers(flagForMulti, indexForInitial, indexForSingle));
148
- setProp(context, indexForMulti, prop);
149
- setValue(context, indexForMulti, null);
150
- setPlayerBuilderIndex(context, indexForMulti, 0);
393
+ const initialFlag = prepareInitialFlag(context, propName, entryIsClassBased, styleSanitizer || null);
394
+ setFlag(context, singleIndex, pointers(initialFlag, indexForInitial, multiIndex));
395
+ setProp(context, singleIndex, propName);
396
+ setValue(context, singleIndex, null);
397
+ setPlayerBuilderIndex(context, singleIndex, 0, directiveIndex);
398
+ setFlag(context, multiIndex, pointers(initialFlag, indexForInitial, singleIndex));
399
+ setProp(context, multiIndex, propName);
400
+ setValue(context, multiIndex, null);
401
+ setPlayerBuilderIndex(context, multiIndex, 0, directiveIndex);
151
402
  }
152
- /** @type {?} */
153
- const masterFlag = pointers(0, 0, multiStart) |
403
+ // the total classes/style values are updated so the next time the context is patched
404
+ // additional style/class bindings from another directive then it knows exactly where
405
+ // to insert them in the context
406
+ singlePropOffsetValues[1 /* ClassesCountPosition */] =
407
+ totalCurrentClassBindings + filteredClassBindingNames.length;
408
+ singlePropOffsetValues[0 /* StylesCountPosition */] =
409
+ totalCurrentStyleBindings + filteredStyleBindingNames.length;
410
+ // there is no initial value flag for the master index since it doesn't
411
+ // reference an initial style value
412
+ /** @type {?} */
413
+ const masterFlag = pointers(0, 0, multiStylesStartIndex) |
154
414
  (onlyProcessSingleClasses ? 16 /* OnlyProcessSingleClasses */ : 0);
155
- setFlag(context, 3 /* MasterFlagPosition */, masterFlag);
156
- setContextDirty(context, initialStylingValues.length > 1);
157
- if (initialStaticClasses) {
158
- context[6 /* PreviousOrCachedMultiClassValue */] = initialStaticClasses.join(' ');
415
+ setFlag(context, 0 /* MasterFlagPosition */, masterFlag);
416
+ }
417
+ /**
418
+ * Searches through the existing registry of directives
419
+ * @param {?} context
420
+ * @param {?} directiveRef
421
+ * @param {?=} styleSanitizer
422
+ * @return {?}
423
+ */
424
+ function findOrPatchDirectiveIntoRegistry(context, directiveRef, styleSanitizer) {
425
+ /** @type {?} */
426
+ const directiveRefs = context[1 /* DirectiveRegistryPosition */];
427
+ /** @type {?} */
428
+ const nextOffsetInsertionIndex = context[4 /* SinglePropOffsetPositions */].length;
429
+ /** @type {?} */
430
+ let directiveIndex;
431
+ /** @type {?} */
432
+ const detectedIndex = getDirectiveRegistryValuesIndexOf(directiveRefs, directiveRef);
433
+ if (detectedIndex === -1) {
434
+ directiveIndex = directiveRefs.length / 4 /* Size */;
435
+ directiveRefs.push(directiveRef, nextOffsetInsertionIndex, false, styleSanitizer || null);
159
436
  }
160
- return context;
437
+ else {
438
+ /** @type {?} */
439
+ const singlePropStartPosition = detectedIndex + 1 /* SinglePropValuesIndexOffset */;
440
+ if ((/** @type {?} */ (directiveRefs[singlePropStartPosition])) >= 0) {
441
+ // the directive has already been patched into the context
442
+ return -1;
443
+ }
444
+ directiveIndex = detectedIndex / 4 /* Size */;
445
+ // because the directive already existed this means that it was set during elementHostAttrs or
446
+ // elementStart which means that the binding values were not here. Therefore, the values below
447
+ // need to be applied so that single class and style properties can be assigned later.
448
+ /** @type {?} */
449
+ const singlePropPositionIndex = detectedIndex + 1 /* SinglePropValuesIndexOffset */;
450
+ directiveRefs[singlePropPositionIndex] = nextOffsetInsertionIndex;
451
+ // the sanitizer is also apart of the binding process and will be used when bindings are
452
+ // applied.
453
+ /** @type {?} */
454
+ const styleSanitizerIndex = detectedIndex + 3 /* StyleSanitizerOffset */;
455
+ directiveRefs[styleSanitizerIndex] = styleSanitizer || null;
456
+ }
457
+ return directiveIndex;
458
+ }
459
+ /**
460
+ * @param {?} context
461
+ * @param {?} bindingName
462
+ * @param {?} start
463
+ * @param {?} end
464
+ * @return {?}
465
+ */
466
+ function getMatchingBindingIndex(context, bindingName, start, end) {
467
+ for (let j = start; j < end; j += 4 /* Size */) {
468
+ if (getProp(context, j) === bindingName)
469
+ return j;
470
+ }
471
+ return -1;
161
472
  }
162
473
  /**
163
474
  * Sets and resolves all `multi` styling on an `StylingContext` so that they can be
164
- * applied to the element once `renderStyleAndClassBindings` is called.
475
+ * applied to the element once `renderStyling` is called.
165
476
  *
166
477
  * All missing styles/class (any values that are not provided in the new `styles`
167
478
  * or `classes` params) will resolve to `null` within their respective positions
@@ -171,36 +482,41 @@ export function createStylingContextTemplate(initialClassDeclarations, initialSt
171
482
  * newly provided style values.
172
483
  * @param {?} classesInput The key/value map of CSS class names that will be used for the update.
173
484
  * @param {?=} stylesInput The key/value map of CSS styles that will be used for the update.
485
+ * @param {?=} directiveRef
174
486
  * @return {?}
175
487
  */
176
- export function updateStylingMap(context, classesInput, stylesInput) {
488
+ export function updateStylingMap(context, classesInput, stylesInput, directiveRef) {
177
489
  stylesInput = stylesInput || null;
178
490
  /** @type {?} */
179
- const element = /** @type {?} */ (((context[5 /* ElementPosition */])));
491
+ const directiveIndex = getDirectiveIndexFromRegistry(context, directiveRef || null);
492
+ /** @type {?} */
493
+ const element = (/** @type {?} */ ((/** @type {?} */ (context[5 /* ElementPosition */]))));
180
494
  /** @type {?} */
181
495
  const classesPlayerBuilder = classesInput instanceof BoundPlayerFactory ?
182
- new ClassAndStylePlayerBuilder(/** @type {?} */ (classesInput), element, 1 /* Class */) :
496
+ new ClassAndStylePlayerBuilder((/** @type {?} */ (classesInput)), element, 1 /* Class */) :
183
497
  null;
184
498
  /** @type {?} */
185
499
  const stylesPlayerBuilder = stylesInput instanceof BoundPlayerFactory ?
186
- new ClassAndStylePlayerBuilder(/** @type {?} */ (stylesInput), element, 2 /* Style */) :
500
+ new ClassAndStylePlayerBuilder((/** @type {?} */ (stylesInput)), element, 2 /* Style */) :
187
501
  null;
188
502
  /** @type {?} */
189
- const classesValue = classesPlayerBuilder ? /** @type {?} */ (((/** @type {?} */ (classesInput)))).value :
503
+ const classesValue = classesPlayerBuilder ?
504
+ (/** @type {?} */ (((/** @type {?} */ (classesInput))))).value :
190
505
  classesInput;
191
506
  /** @type {?} */
192
- const stylesValue = stylesPlayerBuilder ? stylesInput["value"] : stylesInput;
507
+ const stylesValue = stylesPlayerBuilder ? (/** @type {?} */ (stylesInput)).value : stylesInput;
508
+ // early exit (this is what's done to avoid using ctx.bind() to cache the value)
193
509
  /** @type {?} */
194
510
  const ignoreAllClassUpdates = limitToSingleClasses(context) || classesValue === NO_CHANGE ||
195
- classesValue === context[6 /* PreviousOrCachedMultiClassValue */];
511
+ classesValue === context[6 /* CachedClassValueOrInitialClassString */];
196
512
  /** @type {?} */
197
- const ignoreAllStyleUpdates = stylesValue === NO_CHANGE || stylesValue === context[7 /* PreviousMultiStyleValue */];
513
+ const ignoreAllStyleUpdates = stylesValue === NO_CHANGE || stylesValue === context[7 /* CachedStyleValue */];
198
514
  if (ignoreAllClassUpdates && ignoreAllStyleUpdates)
199
515
  return;
200
- context[6 /* PreviousOrCachedMultiClassValue */] = classesValue;
201
- context[7 /* PreviousMultiStyleValue */] = stylesValue;
516
+ context[6 /* CachedClassValueOrInitialClassString */] = classesValue;
517
+ context[7 /* CachedStyleValue */] = stylesValue;
202
518
  /** @type {?} */
203
- let classNames = EMPTY_ARR;
519
+ let classNames = EMPTY_ARRAY;
204
520
  /** @type {?} */
205
521
  let applyAllClasses = false;
206
522
  /** @type {?} */
@@ -227,19 +543,19 @@ export function updateStylingMap(context, classesInput, stylesInput) {
227
543
  applyAllClasses = true;
228
544
  }
229
545
  else {
230
- classNames = classesValue ? Object.keys(classesValue) : EMPTY_ARR;
546
+ classNames = classesValue ? Object.keys(classesValue) : EMPTY_ARRAY;
231
547
  }
232
548
  }
233
549
  /** @type {?} */
234
- const classes = /** @type {?} */ ((classesValue || EMPTY_OBJ));
550
+ const classes = (/** @type {?} */ ((classesValue || EMPTY_OBJ)));
235
551
  /** @type {?} */
236
- const styleProps = stylesValue ? Object.keys(stylesValue) : EMPTY_ARR;
552
+ const styleProps = stylesValue ? Object.keys(stylesValue) : EMPTY_ARRAY;
237
553
  /** @type {?} */
238
554
  const styles = stylesValue || EMPTY_OBJ;
239
555
  /** @type {?} */
240
556
  const classesStartIndex = styleProps.length;
241
557
  /** @type {?} */
242
- const multiStartIndex = getMultiStartIndex(context);
558
+ let multiStartIndex = getMultiStartIndex(context);
243
559
  /** @type {?} */
244
560
  let dirty = false;
245
561
  /** @type {?} */
@@ -274,15 +590,19 @@ export function updateStylingMap(context, classesInput, stylesInput) {
274
590
  const value = getValue(context, ctxIndex);
275
591
  /** @type {?} */
276
592
  const flag = getPointers(context, ctxIndex);
277
- setPlayerBuilderIndex(context, ctxIndex, playerBuilderIndex);
593
+ setPlayerBuilderIndex(context, ctxIndex, playerBuilderIndex, directiveIndex);
278
594
  if (hasValueChanged(flag, value, newValue)) {
279
595
  setValue(context, ctxIndex, newValue);
280
596
  playerBuildersAreDirty = playerBuildersAreDirty || !!playerBuilderIndex;
281
597
  /** @type {?} */
282
598
  const initialValue = getInitialValue(context, flag);
283
- // there is no point in setting this to dirty if the previously
284
- // rendered value was being referenced by the initial style (or null)
285
- if (hasValueChanged(flag, initialValue, newValue)) {
599
+ // SKIP IF INITIAL CHECK
600
+ // If the former `value` is `null` then it means that an initial value
601
+ // could be being rendered on screen. If that is the case then there is
602
+ // no point in updating the value incase it matches. In other words if the
603
+ // new value is the exact same as the previously rendered value (which
604
+ // happens to be the initial value) then do nothing.
605
+ if (value != null || hasValueChanged(flag, initialValue, newValue)) {
286
606
  setDirty(context, ctxIndex, true);
287
607
  dirty = true;
288
608
  }
@@ -292,6 +612,7 @@ export function updateStylingMap(context, classesInput, stylesInput) {
292
612
  /** @type {?} */
293
613
  const indexOfEntry = findEntryPositionByProp(context, newProp, ctxIndex);
294
614
  if (indexOfEntry > 0) {
615
+ // it was found at a later point ... just swap the values
295
616
  /** @type {?} */
296
617
  const valueToCompare = getValue(context, indexOfEntry);
297
618
  /** @type {?} */
@@ -301,7 +622,8 @@ export function updateStylingMap(context, classesInput, stylesInput) {
301
622
  /** @type {?} */
302
623
  const initialValue = getInitialValue(context, flagToCompare);
303
624
  setValue(context, ctxIndex, newValue);
304
- if (hasValueChanged(flagToCompare, initialValue, newValue)) {
625
+ // same if statement logic as above (look for SKIP IF INITIAL CHECK).
626
+ if (valueToCompare != null || hasValueChanged(flagToCompare, initialValue, newValue)) {
305
627
  setDirty(context, ctxIndex, true);
306
628
  playerBuildersAreDirty = playerBuildersAreDirty || !!playerBuilderIndex;
307
629
  dirty = true;
@@ -309,10 +631,11 @@ export function updateStylingMap(context, classesInput, stylesInput) {
309
631
  }
310
632
  }
311
633
  else {
634
+ // we only care to do this if the insertion is in the middle
312
635
  /** @type {?} */
313
- const newFlag = prepareInitialFlag(newProp, isClassBased, getStyleSanitizer(context));
636
+ const newFlag = prepareInitialFlag(context, newProp, isClassBased, getStyleSanitizer(context, directiveIndex));
314
637
  playerBuildersAreDirty = playerBuildersAreDirty || !!playerBuilderIndex;
315
- insertNewMultiProperty(context, ctxIndex, isClassBased, newProp, newFlag, newValue, playerBuilderIndex);
638
+ insertNewMultiProperty(context, ctxIndex, isClassBased, newProp, newFlag, newValue, directiveIndex, playerBuilderIndex);
316
639
  dirty = true;
317
640
  }
318
641
  }
@@ -338,16 +661,22 @@ export function updateStylingMap(context, classesInput, stylesInput) {
338
661
  if (doRemoveValue) {
339
662
  setDirty(context, ctxIndex, true);
340
663
  setValue(context, ctxIndex, null);
664
+ // we keep the player factory the same so that the `nulled` value can
665
+ // be instructed into the player because removing a style and/or a class
666
+ // is a valid animation player instruction.
341
667
  /** @type {?} */
342
668
  const playerBuilderIndex = isClassBased ? classesPlayerBuilderIndex : stylesPlayerBuilderIndex;
343
- setPlayerBuilderIndex(context, ctxIndex, playerBuilderIndex);
669
+ setPlayerBuilderIndex(context, ctxIndex, playerBuilderIndex, directiveIndex);
344
670
  dirty = true;
345
671
  }
346
672
  }
347
673
  ctxIndex += 4 /* Size */;
348
674
  }
675
+ // this means that there are left-over properties in the context that
676
+ // were not detected in the context during the loop above. In that
677
+ // case we want to add the new entries into the list
349
678
  /** @type {?} */
350
- const sanitizer = getStyleSanitizer(context);
679
+ const sanitizer = getStyleSanitizer(context, directiveIndex);
351
680
  while (propIndex < propLimit) {
352
681
  /** @type {?} */
353
682
  const isClassBased = propIndex >= classesStartIndex;
@@ -361,24 +690,42 @@ export function updateStylingMap(context, classesInput, stylesInput) {
361
690
  /** @type {?} */
362
691
  const value = isClassBased ? (applyAllClasses ? true : classes[prop]) : styles[prop];
363
692
  /** @type {?} */
364
- const flag = prepareInitialFlag(prop, isClassBased, sanitizer) | 1 /* Dirty */;
693
+ const flag = prepareInitialFlag(context, prop, isClassBased, sanitizer) | 1 /* Dirty */;
365
694
  /** @type {?} */
366
695
  const playerBuilderIndex = isClassBased ? classesPlayerBuilderIndex : stylesPlayerBuilderIndex;
367
- context.push(flag, prop, value, playerBuilderIndex);
696
+ /** @type {?} */
697
+ const ctxIndex = context.length;
698
+ context.push(flag, prop, value, 0);
699
+ setPlayerBuilderIndex(context, ctxIndex, playerBuilderIndex, directiveIndex);
368
700
  dirty = true;
369
701
  }
370
702
  propIndex++;
371
703
  }
372
704
  if (dirty) {
373
705
  setContextDirty(context, true);
706
+ setDirectiveDirty(context, directiveIndex, true);
374
707
  }
375
708
  if (playerBuildersAreDirty) {
376
709
  setContextPlayersDirty(context, true);
377
710
  }
378
711
  }
379
712
  /**
380
- * Sets and resolves a single styling property/value on the provided `StylingContext` so
381
- * that they can be applied to the element once `renderStyleAndClassBindings` is called.
713
+ * This method will toggle the referenced CSS class (by the provided index)
714
+ * within the given context.
715
+ *
716
+ * @param {?} context The styling context that will be updated with the
717
+ * newly provided class value.
718
+ * @param {?} offset The index of the CSS class which is being updated.
719
+ * @param {?} addOrRemove Whether or not to add or remove the CSS class
720
+ * @param {?=} directiveRef
721
+ * @return {?}
722
+ */
723
+ export function updateClassProp(context, offset, addOrRemove, directiveRef) {
724
+ _updateSingleStylingValue(context, offset, addOrRemove, true, directiveRef);
725
+ }
726
+ /**
727
+ * Sets and resolves a single style value on the provided `StylingContext` so
728
+ * that they can be applied to the element once `renderStyling` is called.
382
729
  *
383
730
  * Note that prop-level styling values are considered higher priority than any styling that
384
731
  * has been applied using `updateStylingMap`, therefore, when styling values are rendered
@@ -387,31 +734,50 @@ export function updateStylingMap(context, classesInput, stylesInput) {
387
734
  *
388
735
  * @param {?} context The styling context that will be updated with the
389
736
  * newly provided style value.
390
- * @param {?} index The index of the property which is being updated.
737
+ * @param {?} offset The index of the property which is being updated.
391
738
  * @param {?} input
739
+ * @param {?=} directiveRef an optional reference to the directive responsible
740
+ * for this binding change. If present then style binding will only
741
+ * actualize if the directive has ownership over this binding
742
+ * (see styling.ts#directives for more information about the algorithm).
392
743
  * @return {?}
393
744
  */
394
- export function updateStyleProp(context, index, input) {
745
+ export function updateStyleProp(context, offset, input, directiveRef) {
746
+ _updateSingleStylingValue(context, offset, input, false, directiveRef);
747
+ }
748
+ /**
749
+ * @param {?} context
750
+ * @param {?} offset
751
+ * @param {?} input
752
+ * @param {?} isClassBased
753
+ * @param {?} directiveRef
754
+ * @return {?}
755
+ */
756
+ function _updateSingleStylingValue(context, offset, input, isClassBased, directiveRef) {
395
757
  /** @type {?} */
396
- const singleIndex = 8 /* SingleStylesStartPosition */ + index * 4 /* Size */;
758
+ const directiveIndex = getDirectiveIndexFromRegistry(context, directiveRef || null);
759
+ /** @type {?} */
760
+ const singleIndex = getSinglePropIndexValue(context, directiveIndex, offset, isClassBased);
397
761
  /** @type {?} */
398
762
  const currValue = getValue(context, singleIndex);
399
763
  /** @type {?} */
400
764
  const currFlag = getPointers(context, singleIndex);
401
765
  /** @type {?} */
766
+ const currDirective = getDirectiveIndexFromEntry(context, singleIndex);
767
+ /** @type {?} */
402
768
  const value = (input instanceof BoundPlayerFactory) ? input.value : input;
403
- // didn't change ... nothing to make a note of
404
- if (hasValueChanged(currFlag, currValue, value)) {
769
+ if (hasValueChanged(currFlag, currValue, value) &&
770
+ allowValueChange(currValue, value, currDirective, directiveIndex)) {
405
771
  /** @type {?} */
406
772
  const isClassBased = (currFlag & 2 /* Class */) === 2 /* Class */;
407
773
  /** @type {?} */
408
- const element = /** @type {?} */ (((context[5 /* ElementPosition */])));
774
+ const element = (/** @type {?} */ ((/** @type {?} */ (context[5 /* ElementPosition */]))));
409
775
  /** @type {?} */
410
776
  const playerBuilder = input instanceof BoundPlayerFactory ?
411
- new ClassAndStylePlayerBuilder(/** @type {?} */ (input), element, isClassBased ? 1 /* Class */ : 2 /* Style */) :
777
+ new ClassAndStylePlayerBuilder((/** @type {?} */ (input)), element, isClassBased ? 1 /* Class */ : 2 /* Style */) :
412
778
  null;
413
779
  /** @type {?} */
414
- const value = /** @type {?} */ ((playerBuilder ? (/** @type {?} */ (input)).value : input));
780
+ const value = (/** @type {?} */ ((playerBuilder ? ((/** @type {?} */ (input))).value : input)));
415
781
  /** @type {?} */
416
782
  const currPlayerIndex = getPlayerBuilderIndex(context, singleIndex);
417
783
  /** @type {?} */
@@ -422,13 +788,23 @@ export function updateStyleProp(context, index, input) {
422
788
  /** @type {?} */
423
789
  const newIndex = setPlayerBuilder(context, playerBuilder, currPlayerIndex);
424
790
  playerBuilderIndex = playerBuilder ? newIndex : 0;
425
- setPlayerBuilderIndex(context, singleIndex, playerBuilderIndex);
426
791
  playerBuildersAreDirty = true;
427
792
  }
793
+ if (playerBuildersAreDirty || currDirective !== directiveIndex) {
794
+ setPlayerBuilderIndex(context, singleIndex, playerBuilderIndex, directiveIndex);
795
+ }
796
+ if (currDirective !== directiveIndex) {
797
+ /** @type {?} */
798
+ const prop = getProp(context, singleIndex);
799
+ /** @type {?} */
800
+ const sanitizer = getStyleSanitizer(context, directiveIndex);
801
+ setSanitizeFlag(context, singleIndex, (sanitizer && sanitizer(prop)) ? true : false);
802
+ }
428
803
  // the value will always get updated (even if the dirty flag is skipped)
429
804
  setValue(context, singleIndex, value);
430
805
  /** @type {?} */
431
806
  const indexForMulti = getMultiOrSingleIndex(currFlag);
807
+ // if the value is the same in the multi-area then there's no point in re-assembling
432
808
  /** @type {?} */
433
809
  const valueForMulti = getValue(context, indexForMulti);
434
810
  if (!valueForMulti || hasValueChanged(currFlag, valueForMulti, value)) {
@@ -443,6 +819,7 @@ export function updateStyleProp(context, index, input) {
443
819
  }
444
820
  setDirty(context, indexForMulti, multiDirty);
445
821
  setDirty(context, singleIndex, singleDirty);
822
+ setDirectiveDirty(context, directiveIndex, true);
446
823
  setContextDirty(context, true);
447
824
  }
448
825
  if (playerBuildersAreDirty) {
@@ -450,21 +827,6 @@ export function updateStyleProp(context, index, input) {
450
827
  }
451
828
  }
452
829
  }
453
- /**
454
- * This method will toggle the referenced CSS class (by the provided index)
455
- * within the given context.
456
- *
457
- * @param {?} context The styling context that will be updated with the
458
- * newly provided class value.
459
- * @param {?} index The index of the CSS class which is being updated.
460
- * @param {?} addOrRemove Whether or not to add or remove the CSS class
461
- * @return {?}
462
- */
463
- export function updateClassProp(context, index, addOrRemove) {
464
- /** @type {?} */
465
- const adjustedIndex = index + context[4 /* ClassOffsetPosition */];
466
- updateStyleProp(context, adjustedIndex, addOrRemove);
467
- }
468
830
  /**
469
831
  * Renders all queued styling using a renderer onto the given element.
470
832
  *
@@ -483,31 +845,44 @@ export function updateClassProp(context, index, addOrRemove) {
483
845
  * to this key/value map instead of being renderered via the renderer.
484
846
  * @param {?=} stylesStore if provided, the updated style values will be applied
485
847
  * to this key/value map instead of being renderered via the renderer.
848
+ * @param {?=} directiveRef an optional directive that will be used to target which
849
+ * styling values are rendered. If left empty, only the bindings that are
850
+ * registered on the template will be rendered.
486
851
  * @return {?} number the total amount of players that got queued for animation (if any)
487
852
  */
488
- export function renderStyleAndClassBindings(context, renderer, rootOrView, isFirstRender, classesStore, stylesStore) {
853
+ export function renderStyling(context, renderer, rootOrView, isFirstRender, classesStore, stylesStore, directiveRef) {
489
854
  /** @type {?} */
490
855
  let totalPlayersQueued = 0;
491
- if (isContextDirty(context)) {
856
+ /** @type {?} */
857
+ const targetDirectiveIndex = getDirectiveIndexFromRegistry(context, directiveRef || null);
858
+ if (isContextDirty(context) && isDirectiveDirty(context, targetDirectiveIndex)) {
492
859
  /** @type {?} */
493
- const flushPlayerBuilders = context[3 /* MasterFlagPosition */] & 8 /* PlayerBuildersDirty */;
860
+ const flushPlayerBuilders = context[0 /* MasterFlagPosition */] & 8 /* PlayerBuildersDirty */;
494
861
  /** @type {?} */
495
- const native = /** @type {?} */ ((context[5 /* ElementPosition */]));
862
+ const native = (/** @type {?} */ (context[5 /* ElementPosition */]));
496
863
  /** @type {?} */
497
864
  const multiStartIndex = getMultiStartIndex(context);
498
865
  /** @type {?} */
499
- const styleSanitizer = getStyleSanitizer(context);
500
- /** @type {?} */
501
866
  const onlySingleClasses = limitToSingleClasses(context);
502
- for (let i = 8 /* SingleStylesStartPosition */; i < context.length; i += 4 /* Size */) {
867
+ /** @type {?} */
868
+ let stillDirty = false;
869
+ for (let i = 9 /* SingleStylesStartPosition */; i < context.length; i += 4 /* Size */) {
503
870
  // there is no point in rendering styles that have not changed on screen
504
871
  if (isDirty(context, i)) {
872
+ /** @type {?} */
873
+ const flag = getPointers(context, i);
874
+ /** @type {?} */
875
+ const directiveIndex = getDirectiveIndexFromEntry(context, i);
876
+ if (targetDirectiveIndex !== directiveIndex) {
877
+ stillDirty = true;
878
+ continue;
879
+ }
505
880
  /** @type {?} */
506
881
  const prop = getProp(context, i);
507
882
  /** @type {?} */
508
883
  const value = getValue(context, i);
509
884
  /** @type {?} */
510
- const flag = getPointers(context, i);
885
+ const styleSanitizer = (flag & 4 /* Sanitize */) ? getStyleSanitizer(context, directiveIndex) : null;
511
886
  /** @type {?} */
512
887
  const playerBuilder = getPlayerBuilder(context, i);
513
888
  /** @type {?} */
@@ -522,6 +897,7 @@ export function renderStyleAndClassBindings(context, renderer, rootOrView, isFir
522
897
  // this check implies that a single value was removed and we
523
898
  // should now defer to a multi value and use that (if set).
524
899
  if (isInSingleRegion && !valueExists(valueToApply, isClassBased)) {
900
+ // single values ALWAYS have a reference to a multi index
525
901
  /** @type {?} */
526
902
  const multiIndex = getMultiOrSingleIndex(flag);
527
903
  valueToApply = getValue(context, multiIndex);
@@ -532,9 +908,15 @@ export function renderStyleAndClassBindings(context, renderer, rootOrView, isFir
532
908
  // note that this should always be a falsy check since `false` is used
533
909
  // for both class and style comparisons (styles can't be false and false
534
910
  // classes are turned off and should therefore defer to their initial values)
535
- if (!valueExists(valueToApply, isClassBased) && readInitialValue) {
911
+ // Note that we ignore class-based deferals because otherwise a class can never
912
+ // be removed in the case that it exists as true in the initial classes list...
913
+ if (!isClassBased && !valueExists(valueToApply, isClassBased) && readInitialValue) {
536
914
  valueToApply = getInitialValue(context, flag);
537
915
  }
916
+ // if the first render is true then we do not want to start applying falsy
917
+ // values to the DOM element's styling. Otherwise then we know there has
918
+ // been a change and even if it's falsy then it's removing something that
919
+ // was truthy before.
538
920
  /** @type {?} */
539
921
  const doApplyValue = isFirstRender ? valueToApply : true;
540
922
  if (doApplyValue) {
@@ -542,9 +924,7 @@ export function renderStyleAndClassBindings(context, renderer, rootOrView, isFir
542
924
  setClass(native, prop, valueToApply ? true : false, renderer, classesStore, playerBuilder);
543
925
  }
544
926
  else {
545
- /** @type {?} */
546
- const sanitizer = (flag & 4 /* Sanitize */) ? styleSanitizer : null;
547
- setStyle(native, prop, /** @type {?} */ (valueToApply), renderer, sanitizer, stylesStore, playerBuilder);
927
+ setStyle(native, prop, (/** @type {?} */ (valueToApply)), renderer, styleSanitizer, stylesStore, playerBuilder);
548
928
  }
549
929
  }
550
930
  setDirty(context, i, false);
@@ -552,25 +932,25 @@ export function renderStyleAndClassBindings(context, renderer, rootOrView, isFir
552
932
  }
553
933
  if (flushPlayerBuilders) {
554
934
  /** @type {?} */
555
- const rootContext = Array.isArray(rootOrView) ? getRootContext(rootOrView) : /** @type {?} */ (rootOrView);
935
+ const rootContext = Array.isArray(rootOrView) ? getRootContext(rootOrView) : (/** @type {?} */ (rootOrView));
556
936
  /** @type {?} */
557
- const playerContext = /** @type {?} */ ((getPlayerContext(context)));
937
+ const playerContext = (/** @type {?} */ (getPlayerContext(context)));
558
938
  /** @type {?} */
559
939
  const playersStartIndex = playerContext[0 /* NonBuilderPlayersStart */];
560
940
  for (let i = 1 /* PlayerBuildersStartPosition */; i < playersStartIndex; i += 2 /* PlayerAndPlayerBuildersTupleSize */) {
561
941
  /** @type {?} */
562
- const builder = /** @type {?} */ (playerContext[i]);
942
+ const builder = (/** @type {?} */ (playerContext[i]));
563
943
  /** @type {?} */
564
944
  const playerInsertionIndex = i + 1 /* PlayerOffsetPosition */;
565
945
  /** @type {?} */
566
- const oldPlayer = /** @type {?} */ (playerContext[playerInsertionIndex]);
946
+ const oldPlayer = (/** @type {?} */ (playerContext[playerInsertionIndex]));
567
947
  if (builder) {
568
948
  /** @type {?} */
569
949
  const player = builder.buildPlayer(oldPlayer, isFirstRender);
570
950
  if (player !== undefined) {
571
951
  if (player != null) {
572
952
  /** @type {?} */
573
- const wasQueued = addPlayerInternal(playerContext, rootContext, /** @type {?} */ (native), player, playerInsertionIndex);
953
+ const wasQueued = addPlayerInternal(playerContext, rootContext, (/** @type {?} */ (native)), player, playerInsertionIndex);
574
954
  wasQueued && totalPlayersQueued++;
575
955
  }
576
956
  if (oldPlayer) {
@@ -586,7 +966,8 @@ export function renderStyleAndClassBindings(context, renderer, rootOrView, isFir
586
966
  }
587
967
  setContextPlayersDirty(context, false);
588
968
  }
589
- setContextDirty(context, false);
969
+ setDirectiveDirty(context, targetDirectiveIndex, false);
970
+ setContextDirty(context, stillDirty);
590
971
  }
591
972
  return totalPlayersQueued;
592
973
  }
@@ -605,7 +986,7 @@ export function renderStyleAndClassBindings(context, renderer, rootOrView, isFir
605
986
  * @param {?=} playerBuilder
606
987
  * @return {?}
607
988
  */
608
- function setStyle(native, prop, value, renderer, sanitizer, store, playerBuilder) {
989
+ export function setStyle(native, prop, value, renderer, sanitizer, store, playerBuilder) {
609
990
  value = sanitizer && value ? sanitizer(prop, value) : value;
610
991
  if (store || playerBuilder) {
611
992
  if (store) {
@@ -616,6 +997,8 @@ function setStyle(native, prop, value, renderer, sanitizer, store, playerBuilder
616
997
  }
617
998
  }
618
999
  else if (value) {
1000
+ value = value.toString(); // opacity, z-index and flexbox all have number values which may not
1001
+ // assign as numbers
619
1002
  ngDevMode && ngDevMode.rendererSetStyle++;
620
1003
  isProceduralRenderer(renderer) ?
621
1004
  renderer.setStyle(native, prop, value, RendererStyleFlags3.DashCase) :
@@ -662,6 +1045,20 @@ function setClass(native, className, add, renderer, store, playerBuilder) {
662
1045
  native['classList'].remove(className);
663
1046
  }
664
1047
  }
1048
+ /**
1049
+ * @param {?} context
1050
+ * @param {?} index
1051
+ * @param {?} sanitizeYes
1052
+ * @return {?}
1053
+ */
1054
+ function setSanitizeFlag(context, index, sanitizeYes) {
1055
+ if (sanitizeYes) {
1056
+ ((/** @type {?} */ (context[index]))) |= 4 /* Sanitize */;
1057
+ }
1058
+ else {
1059
+ ((/** @type {?} */ (context[index]))) &= ~4 /* Sanitize */;
1060
+ }
1061
+ }
665
1062
  /**
666
1063
  * @param {?} context
667
1064
  * @param {?} index
@@ -670,12 +1067,12 @@ function setClass(native, className, add, renderer, store, playerBuilder) {
670
1067
  */
671
1068
  function setDirty(context, index, isDirtyYes) {
672
1069
  /** @type {?} */
673
- const adjustedIndex = index >= 8 /* SingleStylesStartPosition */ ? (index + 0 /* FlagsOffset */) : index;
1070
+ const adjustedIndex = index >= 9 /* SingleStylesStartPosition */ ? (index + 0 /* FlagsOffset */) : index;
674
1071
  if (isDirtyYes) {
675
- (/** @type {?} */ (context[adjustedIndex])) |= 1 /* Dirty */;
1072
+ ((/** @type {?} */ (context[adjustedIndex]))) |= 1 /* Dirty */;
676
1073
  }
677
1074
  else {
678
- (/** @type {?} */ (context[adjustedIndex])) &= ~1 /* Dirty */;
1075
+ ((/** @type {?} */ (context[adjustedIndex]))) &= ~1 /* Dirty */;
679
1076
  }
680
1077
  }
681
1078
  /**
@@ -685,18 +1082,18 @@ function setDirty(context, index, isDirtyYes) {
685
1082
  */
686
1083
  function isDirty(context, index) {
687
1084
  /** @type {?} */
688
- const adjustedIndex = index >= 8 /* SingleStylesStartPosition */ ? (index + 0 /* FlagsOffset */) : index;
689
- return ((/** @type {?} */ (context[adjustedIndex])) & 1 /* Dirty */) == 1 /* Dirty */;
1085
+ const adjustedIndex = index >= 9 /* SingleStylesStartPosition */ ? (index + 0 /* FlagsOffset */) : index;
1086
+ return (((/** @type {?} */ (context[adjustedIndex]))) & 1 /* Dirty */) == 1 /* Dirty */;
690
1087
  }
691
1088
  /**
692
1089
  * @param {?} context
693
1090
  * @param {?} index
694
1091
  * @return {?}
695
1092
  */
696
- function isClassBased(context, index) {
1093
+ export function isClassBasedValue(context, index) {
697
1094
  /** @type {?} */
698
- const adjustedIndex = index >= 8 /* SingleStylesStartPosition */ ? (index + 0 /* FlagsOffset */) : index;
699
- return ((/** @type {?} */ (context[adjustedIndex])) & 2 /* Class */) == 2 /* Class */;
1095
+ const adjustedIndex = index >= 9 /* SingleStylesStartPosition */ ? (index + 0 /* FlagsOffset */) : index;
1096
+ return (((/** @type {?} */ (context[adjustedIndex]))) & 2 /* Class */) == 2 /* Class */;
700
1097
  }
701
1098
  /**
702
1099
  * @param {?} context
@@ -705,8 +1102,8 @@ function isClassBased(context, index) {
705
1102
  */
706
1103
  function isSanitizable(context, index) {
707
1104
  /** @type {?} */
708
- const adjustedIndex = index >= 8 /* SingleStylesStartPosition */ ? (index + 0 /* FlagsOffset */) : index;
709
- return ((/** @type {?} */ (context[adjustedIndex])) & 4 /* Sanitize */) == 4 /* Sanitize */;
1105
+ const adjustedIndex = index >= 9 /* SingleStylesStartPosition */ ? (index + 0 /* FlagsOffset */) : index;
1106
+ return (((/** @type {?} */ (context[adjustedIndex]))) & 4 /* Sanitize */) == 4 /* Sanitize */;
710
1107
  }
711
1108
  /**
712
1109
  * @param {?} configFlag
@@ -715,8 +1112,8 @@ function isSanitizable(context, index) {
715
1112
  * @return {?}
716
1113
  */
717
1114
  function pointers(configFlag, staticIndex, dynamicIndex) {
718
- return (configFlag & 31 /* BitMask */) | (staticIndex << 5 /* BitCountSize */) |
719
- (dynamicIndex << (14 /* BitCountSize */ + 5 /* BitCountSize */));
1115
+ return (configFlag & 63 /* BitMask */) | (staticIndex << 6 /* BitCountSize */) |
1116
+ (dynamicIndex << (14 /* BitCountSize */ + 6 /* BitCountSize */));
720
1117
  }
721
1118
  /**
722
1119
  * @param {?} context
@@ -726,14 +1123,19 @@ function pointers(configFlag, staticIndex, dynamicIndex) {
726
1123
  function getInitialValue(context, flag) {
727
1124
  /** @type {?} */
728
1125
  const index = getInitialIndex(flag);
729
- return /** @type {?} */ (context[2 /* InitialStylesPosition */][index]);
1126
+ /** @type {?} */
1127
+ const entryIsClassBased = flag & 2 /* Class */;
1128
+ /** @type {?} */
1129
+ const initialValues = entryIsClassBased ? context[3 /* InitialClassValuesPosition */] :
1130
+ context[2 /* InitialStyleValuesPosition */];
1131
+ return initialValues[index];
730
1132
  }
731
1133
  /**
732
1134
  * @param {?} flag
733
1135
  * @return {?}
734
1136
  */
735
1137
  function getInitialIndex(flag) {
736
- return (flag >> 5 /* BitCountSize */) & 16383 /* BitMask */;
1138
+ return (flag >> 6 /* BitCountSize */) & 16383 /* BitMask */;
737
1139
  }
738
1140
  /**
739
1141
  * @param {?} flag
@@ -741,22 +1143,15 @@ function getInitialIndex(flag) {
741
1143
  */
742
1144
  function getMultiOrSingleIndex(flag) {
743
1145
  /** @type {?} */
744
- const index = (flag >> (14 /* BitCountSize */ + 5 /* BitCountSize */)) & 16383 /* BitMask */;
745
- return index >= 8 /* SingleStylesStartPosition */ ? index : -1;
1146
+ const index = (flag >> (14 /* BitCountSize */ + 6 /* BitCountSize */)) & 16383 /* BitMask */;
1147
+ return index >= 9 /* SingleStylesStartPosition */ ? index : -1;
746
1148
  }
747
1149
  /**
748
1150
  * @param {?} context
749
1151
  * @return {?}
750
1152
  */
751
1153
  function getMultiStartIndex(context) {
752
- return /** @type {?} */ (getMultiOrSingleIndex(context[3 /* MasterFlagPosition */]));
753
- }
754
- /**
755
- * @param {?} context
756
- * @return {?}
757
- */
758
- function getStyleSanitizer(context) {
759
- return context[1 /* StyleSanitizerPosition */];
1154
+ return (/** @type {?} */ (getMultiOrSingleIndex(context[0 /* MasterFlagPosition */])));
760
1155
  }
761
1156
  /**
762
1157
  * @param {?} context
@@ -784,7 +1179,7 @@ function setValue(context, index, value) {
784
1179
  */
785
1180
  function hasPlayerBuilderChanged(context, builder, index) {
786
1181
  /** @type {?} */
787
- const playerContext = /** @type {?} */ ((context[0 /* PlayerContext */]));
1182
+ const playerContext = (/** @type {?} */ (context[8 /* PlayerContext */]));
788
1183
  if (builder) {
789
1184
  if (!playerContext || index === 0) {
790
1185
  return true;
@@ -803,7 +1198,7 @@ function hasPlayerBuilderChanged(context, builder, index) {
803
1198
  */
804
1199
  function setPlayerBuilder(context, builder, insertionIndex) {
805
1200
  /** @type {?} */
806
- let playerContext = context[0 /* PlayerContext */] || allocPlayerContext(context);
1201
+ let playerContext = context[8 /* PlayerContext */] || allocPlayerContext(context);
807
1202
  if (insertionIndex > 0) {
808
1203
  playerContext[insertionIndex] = builder;
809
1204
  }
@@ -815,14 +1210,25 @@ function setPlayerBuilder(context, builder, insertionIndex) {
815
1210
  }
816
1211
  return insertionIndex;
817
1212
  }
1213
+ /**
1214
+ * @param {?} directiveIndex
1215
+ * @param {?} playerIndex
1216
+ * @return {?}
1217
+ */
1218
+ export function directiveOwnerPointers(directiveIndex, playerIndex) {
1219
+ return (playerIndex << 16 /* BitCountSize */) | directiveIndex;
1220
+ }
818
1221
  /**
819
1222
  * @param {?} context
820
1223
  * @param {?} index
821
1224
  * @param {?} playerBuilderIndex
1225
+ * @param {?} directiveIndex
822
1226
  * @return {?}
823
1227
  */
824
- function setPlayerBuilderIndex(context, index, playerBuilderIndex) {
825
- context[index + 3 /* PlayerBuilderIndexOffset */] = playerBuilderIndex;
1228
+ function setPlayerBuilderIndex(context, index, playerBuilderIndex, directiveIndex) {
1229
+ /** @type {?} */
1230
+ const value = directiveOwnerPointers(directiveIndex, playerBuilderIndex);
1231
+ context[index + 3 /* PlayerBuilderIndexOffset */] = value;
826
1232
  }
827
1233
  /**
828
1234
  * @param {?} context
@@ -830,7 +1236,12 @@ function setPlayerBuilderIndex(context, index, playerBuilderIndex) {
830
1236
  * @return {?}
831
1237
  */
832
1238
  function getPlayerBuilderIndex(context, index) {
833
- return (/** @type {?} */ (context[index + 3 /* PlayerBuilderIndexOffset */])) || 0;
1239
+ /** @type {?} */
1240
+ const flag = (/** @type {?} */ (context[index + 3 /* PlayerBuilderIndexOffset */]));
1241
+ /** @type {?} */
1242
+ const playerBuilderIndex = (flag >> 16 /* BitCountSize */) &
1243
+ 65535 /* BitMask */;
1244
+ return playerBuilderIndex;
834
1245
  }
835
1246
  /**
836
1247
  * @param {?} context
@@ -842,9 +1253,9 @@ function getPlayerBuilder(context, index) {
842
1253
  const playerBuilderIndex = getPlayerBuilderIndex(context, index);
843
1254
  if (playerBuilderIndex) {
844
1255
  /** @type {?} */
845
- const playerContext = context[0 /* PlayerContext */];
1256
+ const playerContext = context[8 /* PlayerContext */];
846
1257
  if (playerContext) {
847
- return /** @type {?} */ (playerContext[playerBuilderIndex]);
1258
+ return (/** @type {?} */ (playerContext[playerBuilderIndex]));
848
1259
  }
849
1260
  }
850
1261
  return null;
@@ -857,7 +1268,7 @@ function getPlayerBuilder(context, index) {
857
1268
  */
858
1269
  function setFlag(context, index, flag) {
859
1270
  /** @type {?} */
860
- const adjustedIndex = index === 3 /* MasterFlagPosition */ ? index : (index + 0 /* FlagsOffset */);
1271
+ const adjustedIndex = index === 0 /* MasterFlagPosition */ ? index : (index + 0 /* FlagsOffset */);
861
1272
  context[adjustedIndex] = flag;
862
1273
  }
863
1274
  /**
@@ -867,38 +1278,38 @@ function setFlag(context, index, flag) {
867
1278
  */
868
1279
  function getPointers(context, index) {
869
1280
  /** @type {?} */
870
- const adjustedIndex = index === 3 /* MasterFlagPosition */ ? index : (index + 0 /* FlagsOffset */);
871
- return /** @type {?} */ (context[adjustedIndex]);
1281
+ const adjustedIndex = index === 0 /* MasterFlagPosition */ ? index : (index + 0 /* FlagsOffset */);
1282
+ return (/** @type {?} */ (context[adjustedIndex]));
872
1283
  }
873
1284
  /**
874
1285
  * @param {?} context
875
1286
  * @param {?} index
876
1287
  * @return {?}
877
1288
  */
878
- function getValue(context, index) {
879
- return /** @type {?} */ (context[index + 2 /* ValueOffset */]);
1289
+ export function getValue(context, index) {
1290
+ return (/** @type {?} */ (context[index + 2 /* ValueOffset */]));
880
1291
  }
881
1292
  /**
882
1293
  * @param {?} context
883
1294
  * @param {?} index
884
1295
  * @return {?}
885
1296
  */
886
- function getProp(context, index) {
887
- return /** @type {?} */ (context[index + 1 /* PropertyOffset */]);
1297
+ export function getProp(context, index) {
1298
+ return (/** @type {?} */ (context[index + 1 /* PropertyOffset */]));
888
1299
  }
889
1300
  /**
890
1301
  * @param {?} context
891
1302
  * @return {?}
892
1303
  */
893
1304
  export function isContextDirty(context) {
894
- return isDirty(context, 3 /* MasterFlagPosition */);
1305
+ return isDirty(context, 0 /* MasterFlagPosition */);
895
1306
  }
896
1307
  /**
897
1308
  * @param {?} context
898
1309
  * @return {?}
899
1310
  */
900
1311
  export function limitToSingleClasses(context) {
901
- return context[3 /* MasterFlagPosition */] & 16 /* OnlyProcessSingleClasses */;
1312
+ return context[0 /* MasterFlagPosition */] & 16 /* OnlyProcessSingleClasses */;
902
1313
  }
903
1314
  /**
904
1315
  * @param {?} context
@@ -906,7 +1317,7 @@ export function limitToSingleClasses(context) {
906
1317
  * @return {?}
907
1318
  */
908
1319
  export function setContextDirty(context, isDirtyYes) {
909
- setDirty(context, 3 /* MasterFlagPosition */, isDirtyYes);
1320
+ setDirty(context, 0 /* MasterFlagPosition */, isDirtyYes);
910
1321
  }
911
1322
  /**
912
1323
  * @param {?} context
@@ -915,10 +1326,10 @@ export function setContextDirty(context, isDirtyYes) {
915
1326
  */
916
1327
  export function setContextPlayersDirty(context, isDirtyYes) {
917
1328
  if (isDirtyYes) {
918
- (/** @type {?} */ (context[3 /* MasterFlagPosition */])) |= 8 /* PlayerBuildersDirty */;
1329
+ ((/** @type {?} */ (context[0 /* MasterFlagPosition */]))) |= 8 /* PlayerBuildersDirty */;
919
1330
  }
920
1331
  else {
921
- (/** @type {?} */ (context[3 /* MasterFlagPosition */])) &= ~8 /* PlayerBuildersDirty */;
1332
+ ((/** @type {?} */ (context[0 /* MasterFlagPosition */]))) &= ~8 /* PlayerBuildersDirty */;
922
1333
  }
923
1334
  }
924
1335
  /**
@@ -977,11 +1388,15 @@ function swapMultiContextEntries(context, indexA, indexB) {
977
1388
  setValue(context, indexA, getValue(context, indexB));
978
1389
  setProp(context, indexA, getProp(context, indexB));
979
1390
  setFlag(context, indexA, getPointers(context, indexB));
980
- setPlayerBuilderIndex(context, indexA, getPlayerBuilderIndex(context, indexB));
1391
+ /** @type {?} */
1392
+ const playerIndexA = getPlayerBuilderIndex(context, indexB);
1393
+ /** @type {?} */
1394
+ const directiveIndexA = 0;
1395
+ setPlayerBuilderIndex(context, indexA, playerIndexA, directiveIndexA);
981
1396
  setValue(context, indexB, tmpValue);
982
1397
  setProp(context, indexB, tmpProp);
983
1398
  setFlag(context, indexB, tmpFlag);
984
- setPlayerBuilderIndex(context, indexB, tmpPlayerBuilderIndex);
1399
+ setPlayerBuilderIndex(context, indexB, tmpPlayerBuilderIndex, directiveIndexA);
985
1400
  }
986
1401
  /**
987
1402
  * @param {?} context
@@ -1001,7 +1416,7 @@ function updateSinglePointerValues(context, indexStartPosition) {
1001
1416
  const initialIndexForSingle = getInitialIndex(singleFlag);
1002
1417
  /** @type {?} */
1003
1418
  const flagValue = (isDirty(context, singleIndex) ? 1 /* Dirty */ : 0 /* None */) |
1004
- (isClassBased(context, singleIndex) ? 2 /* Class */ : 0 /* None */) |
1419
+ (isClassBasedValue(context, singleIndex) ? 2 /* Class */ : 0 /* None */) |
1005
1420
  (isSanitizable(context, singleIndex) ? 4 /* Sanitize */ : 0 /* None */);
1006
1421
  /** @type {?} */
1007
1422
  const updatedFlag = pointers(flagValue, initialIndexForSingle, i);
@@ -1016,14 +1431,16 @@ function updateSinglePointerValues(context, indexStartPosition) {
1016
1431
  * @param {?} name
1017
1432
  * @param {?} flag
1018
1433
  * @param {?} value
1434
+ * @param {?} directiveIndex
1019
1435
  * @param {?} playerIndex
1020
1436
  * @return {?}
1021
1437
  */
1022
- function insertNewMultiProperty(context, index, classBased, name, flag, value, playerIndex) {
1438
+ function insertNewMultiProperty(context, index, classBased, name, flag, value, directiveIndex, playerIndex) {
1023
1439
  /** @type {?} */
1024
1440
  const doShift = index < context.length;
1025
1441
  // prop does not exist in the list, add it in
1026
- context.splice(index, 0, flag | 1 /* Dirty */ | (classBased ? 2 /* Class */ : 0 /* None */), name, value, playerIndex);
1442
+ context.splice(index, 0, flag | 1 /* Dirty */ | (classBased ? 2 /* Class */ : 0 /* None */), name, value, 0);
1443
+ setPlayerBuilderIndex(context, index, playerIndex, directiveIndex);
1027
1444
  if (doShift) {
1028
1445
  // because the value was inserted midway into the array then we
1029
1446
  // need to update all the shifted multi values' single value
@@ -1043,19 +1460,28 @@ function valueExists(value, isClassBased) {
1043
1460
  return value !== null;
1044
1461
  }
1045
1462
  /**
1046
- * @param {?} name
1047
- * @param {?} isClassBased
1463
+ * @param {?} context
1464
+ * @param {?} prop
1465
+ * @param {?} entryIsClassBased
1048
1466
  * @param {?=} sanitizer
1049
1467
  * @return {?}
1050
1468
  */
1051
- function prepareInitialFlag(name, isClassBased, sanitizer) {
1052
- if (isClassBased) {
1053
- return 2 /* Class */;
1469
+ function prepareInitialFlag(context, prop, entryIsClassBased, sanitizer) {
1470
+ /** @type {?} */
1471
+ let flag = (sanitizer && sanitizer(prop)) ? 4 /* Sanitize */ : 0 /* None */;
1472
+ /** @type {?} */
1473
+ let initialIndex;
1474
+ if (entryIsClassBased) {
1475
+ flag |= 2 /* Class */;
1476
+ initialIndex =
1477
+ getInitialStylingValuesIndexOf(context[3 /* InitialClassValuesPosition */], prop);
1054
1478
  }
1055
- else if (sanitizer && sanitizer(name)) {
1056
- return 4 /* Sanitize */;
1479
+ else {
1480
+ initialIndex =
1481
+ getInitialStylingValuesIndexOf(context[2 /* InitialStyleValuesPosition */], prop);
1057
1482
  }
1058
- return 0 /* None */;
1483
+ initialIndex = initialIndex > 0 ? (initialIndex + 1 /* ValueOffset */) : 0;
1484
+ return pointers(flag, initialIndex, 0);
1059
1485
  }
1060
1486
  /**
1061
1487
  * @param {?} flag
@@ -1075,7 +1501,7 @@ function hasValueChanged(flag, a, b) {
1075
1501
  // would fail since a new String() instance is created
1076
1502
  if (!isClassBased && hasValues && usesSanitizer) {
1077
1503
  // we know for sure we're dealing with strings at this point
1078
- return (/** @type {?} */ (a)).toString() !== (/** @type {?} */ (b)).toString();
1504
+ return ((/** @type {?} */ (a))).toString() !== ((/** @type {?} */ (b))).toString();
1079
1505
  }
1080
1506
  // everything else is safe to check with a normal equality check
1081
1507
  return a !== b;
@@ -1094,7 +1520,7 @@ export class ClassAndStylePlayerBuilder {
1094
1520
  this._type = _type;
1095
1521
  this._values = {};
1096
1522
  this._dirty = false;
1097
- this._factory = /** @type {?} */ (factory);
1523
+ this._factory = (/** @type {?} */ (factory));
1098
1524
  }
1099
1525
  /**
1100
1526
  * @param {?} prop
@@ -1118,7 +1544,7 @@ export class ClassAndStylePlayerBuilder {
1118
1544
  // `setValue` which means no new player will be provided.
1119
1545
  if (this._dirty) {
1120
1546
  /** @type {?} */
1121
- const player = this._factory.fn(this._element, this._type, /** @type {?} */ ((this._values)), isFirstRender, currentPlayer || null);
1547
+ const player = this._factory.fn(this._element, this._type, (/** @type {?} */ (this._values)), isFirstRender, currentPlayer || null);
1122
1548
  this._values = {};
1123
1549
  this._dirty = false;
1124
1550
  return player;
@@ -1127,16 +1553,304 @@ export class ClassAndStylePlayerBuilder {
1127
1553
  }
1128
1554
  }
1129
1555
  if (false) {
1130
- /** @type {?} */
1556
+ /**
1557
+ * @type {?}
1558
+ * @private
1559
+ */
1131
1560
  ClassAndStylePlayerBuilder.prototype._values;
1132
- /** @type {?} */
1561
+ /**
1562
+ * @type {?}
1563
+ * @private
1564
+ */
1133
1565
  ClassAndStylePlayerBuilder.prototype._dirty;
1134
- /** @type {?} */
1566
+ /**
1567
+ * @type {?}
1568
+ * @private
1569
+ */
1135
1570
  ClassAndStylePlayerBuilder.prototype._factory;
1136
- /** @type {?} */
1571
+ /**
1572
+ * @type {?}
1573
+ * @private
1574
+ */
1137
1575
  ClassAndStylePlayerBuilder.prototype._element;
1138
- /** @type {?} */
1576
+ /**
1577
+ * @type {?}
1578
+ * @private
1579
+ */
1139
1580
  ClassAndStylePlayerBuilder.prototype._type;
1140
1581
  }
1141
-
1142
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"class_and_style_bindings.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/styling/class_and_style_bindings.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport {StyleSanitizeFn} from '../../sanitization/style_sanitizer';\nimport {InitialStylingFlags} from '../interfaces/definition';\nimport {BindingStore, BindingType, Player, PlayerBuilder, PlayerFactory, PlayerIndex} from '../interfaces/player';\nimport {Renderer3, RendererStyleFlags3, isProceduralRenderer} from '../interfaces/renderer';\nimport {InitialStyles, StylingContext, StylingFlags, StylingIndex} from '../interfaces/styling';\nimport {LViewData, RootContext} from '../interfaces/view';\nimport {NO_CHANGE} from '../tokens';\nimport {getRootContext} from '../util';\n\nimport {BoundPlayerFactory} from './player_factory';\nimport {addPlayerInternal, allocPlayerContext, createEmptyStylingContext, getPlayerContext} from './util';\n\nconst EMPTY_ARR: any[] = [];\nconst EMPTY_OBJ: {[key: string]: any} = {};\n\n\n/**\n * Creates a styling context template where styling information is stored.\n * Any styles that are later referenced using `updateStyleProp` must be\n * passed in within this function. Initial values for those styles are to\n * be declared after all initial style properties are declared (this change in\n * mode between declarations and initial styles is made possible using a special\n * enum value found in `definition.ts`).\n *\n * @param initialStyleDeclarations a list of style declarations and initial style values\n *    that are used later within the styling context.\n *\n *    -> ['width', 'height', SPECIAL_ENUM_VAL, 'width', '100px']\n *       This implies that `width` and `height` will be later styled and that the `width`\n *       property has an initial value of `100px`.\n *\n * @param initialClassDeclarations a list of class declarations and initial class values\n *    that are used later within the styling context.\n *\n *    -> ['foo', 'bar', SPECIAL_ENUM_VAL, 'foo', true]\n *       This implies that `foo` and `bar` will be later styled and that the `foo`\n *       class will be applied to the element as an initial class since it's true\n */\nexport function createStylingContextTemplate(\n    initialClassDeclarations?: (string | boolean | InitialStylingFlags)[] | null,\n    initialStyleDeclarations?: (string | boolean | InitialStylingFlags)[] | null,\n    styleSanitizer?: StyleSanitizeFn | null, onlyProcessSingleClasses?: boolean): StylingContext {\n  const initialStylingValues: InitialStyles = [null];\n  const context: StylingContext =\n      createEmptyStylingContext(null, styleSanitizer, initialStylingValues);\n\n  // we use two maps since a class name might collide with a CSS style prop\n  const stylesLookup: {[key: string]: number} = {};\n  const classesLookup: {[key: string]: number} = {};\n\n  let totalStyleDeclarations = 0;\n  if (initialStyleDeclarations) {\n    let hasPassedDeclarations = false;\n    for (let i = 0; i < initialStyleDeclarations.length; i++) {\n      const v = initialStyleDeclarations[i] as string | InitialStylingFlags;\n\n      // this flag value marks where the declarations end the initial values begin\n      if (v === InitialStylingFlags.VALUES_MODE) {\n        hasPassedDeclarations = true;\n      } else {\n        const prop = v as string;\n        if (hasPassedDeclarations) {\n          const value = initialStyleDeclarations[++i] as string;\n          initialStylingValues.push(value);\n          stylesLookup[prop] = initialStylingValues.length - 1;\n        } else {\n          totalStyleDeclarations++;\n          stylesLookup[prop] = 0;\n        }\n      }\n    }\n  }\n\n  // make where the class offsets begin\n  context[StylingIndex.ClassOffsetPosition] = totalStyleDeclarations;\n\n  const initialStaticClasses: string[]|null = onlyProcessSingleClasses ? [] : null;\n  if (initialClassDeclarations) {\n    let hasPassedDeclarations = false;\n    for (let i = 0; i < initialClassDeclarations.length; i++) {\n      const v = initialClassDeclarations[i] as string | boolean | InitialStylingFlags;\n      // this flag value marks where the declarations end the initial values begin\n      if (v === InitialStylingFlags.VALUES_MODE) {\n        hasPassedDeclarations = true;\n      } else {\n        const className = v as string;\n        if (hasPassedDeclarations) {\n          const value = initialClassDeclarations[++i] as boolean;\n          initialStylingValues.push(value);\n          classesLookup[className] = initialStylingValues.length - 1;\n          initialStaticClasses && initialStaticClasses.push(className);\n        } else {\n          classesLookup[className] = 0;\n        }\n      }\n    }\n  }\n\n  const styleProps = Object.keys(stylesLookup);\n  const classNames = Object.keys(classesLookup);\n  const classNamesIndexStart = styleProps.length;\n  const totalProps = styleProps.length + classNames.length;\n\n  // *2 because we are filling for both single and multi style spaces\n  const maxLength = totalProps * StylingIndex.Size * 2 + StylingIndex.SingleStylesStartPosition;\n\n  // we need to fill the array from the start so that we can access\n  // both the multi and the single array positions in the same loop block\n  for (let i = StylingIndex.SingleStylesStartPosition; i < maxLength; i++) {\n    context.push(null);\n  }\n\n  const singleStart = StylingIndex.SingleStylesStartPosition;\n  const multiStart = totalProps * StylingIndex.Size + StylingIndex.SingleStylesStartPosition;\n\n  // fill single and multi-level styles\n  for (let i = 0; i < totalProps; i++) {\n    const isClassBased = i >= classNamesIndexStart;\n    const prop = isClassBased ? classNames[i - classNamesIndexStart] : styleProps[i];\n    const indexForInitial = isClassBased ? classesLookup[prop] : stylesLookup[prop];\n    const initialValue = initialStylingValues[indexForInitial];\n\n    const indexForMulti = i * StylingIndex.Size + multiStart;\n    const indexForSingle = i * StylingIndex.Size + singleStart;\n    const initialFlag = prepareInitialFlag(prop, isClassBased, styleSanitizer || null);\n\n    setFlag(context, indexForSingle, pointers(initialFlag, indexForInitial, indexForMulti));\n    setProp(context, indexForSingle, prop);\n    setValue(context, indexForSingle, null);\n    setPlayerBuilderIndex(context, indexForSingle, 0);\n\n    const flagForMulti =\n        initialFlag | (initialValue !== null ? StylingFlags.Dirty : StylingFlags.None);\n    setFlag(context, indexForMulti, pointers(flagForMulti, indexForInitial, indexForSingle));\n    setProp(context, indexForMulti, prop);\n    setValue(context, indexForMulti, null);\n    setPlayerBuilderIndex(context, indexForMulti, 0);\n  }\n\n  // there is no initial value flag for the master index since it doesn't\n  // reference an initial style value\n  const masterFlag = pointers(0, 0, multiStart) |\n      (onlyProcessSingleClasses ? StylingFlags.OnlyProcessSingleClasses : 0);\n  setFlag(context, StylingIndex.MasterFlagPosition, masterFlag);\n  setContextDirty(context, initialStylingValues.length > 1);\n\n  if (initialStaticClasses) {\n    context[StylingIndex.PreviousOrCachedMultiClassValue] = initialStaticClasses.join(' ');\n  }\n\n  return context;\n}\n\n/**\n * Sets and resolves all `multi` styling on an `StylingContext` so that they can be\n * applied to the element once `renderStyleAndClassBindings` is called.\n *\n * All missing styles/class (any values that are not provided in the new `styles`\n * or `classes` params) will resolve to `null` within their respective positions\n * in the context.\n *\n * @param context The styling context that will be updated with the\n *    newly provided style values.\n * @param classesInput The key/value map of CSS class names that will be used for the update.\n * @param stylesInput The key/value map of CSS styles that will be used for the update.\n */\nexport function updateStylingMap(\n    context: StylingContext, classesInput: {[key: string]: any} | string |\n        BoundPlayerFactory<null|string|{[key: string]: any}>| NO_CHANGE | null,\n    stylesInput?: {[key: string]: any} | BoundPlayerFactory<null|{[key: string]: any}>| NO_CHANGE |\n        null): void {\n  stylesInput = stylesInput || null;\n\n  const element = context[StylingIndex.ElementPosition] !as HTMLElement;\n  const classesPlayerBuilder = classesInput instanceof BoundPlayerFactory ?\n      new ClassAndStylePlayerBuilder(classesInput as any, element, BindingType.Class) :\n      null;\n  const stylesPlayerBuilder = stylesInput instanceof BoundPlayerFactory ?\n      new ClassAndStylePlayerBuilder(stylesInput as any, element, BindingType.Style) :\n      null;\n\n  const classesValue = classesPlayerBuilder ?\n      (classesInput as BoundPlayerFactory<{[key: string]: any}|string>) !.value :\n      classesInput;\n  const stylesValue = stylesPlayerBuilder ? stylesInput !.value : stylesInput;\n  // early exit (this is what's done to avoid using ctx.bind() to cache the value)\n  const ignoreAllClassUpdates = limitToSingleClasses(context) || classesValue === NO_CHANGE ||\n      classesValue === context[StylingIndex.PreviousOrCachedMultiClassValue];\n  const ignoreAllStyleUpdates =\n      stylesValue === NO_CHANGE || stylesValue === context[StylingIndex.PreviousMultiStyleValue];\n  if (ignoreAllClassUpdates && ignoreAllStyleUpdates) return;\n\n  context[StylingIndex.PreviousOrCachedMultiClassValue] = classesValue;\n  context[StylingIndex.PreviousMultiStyleValue] = stylesValue;\n\n  let classNames: string[] = EMPTY_ARR;\n  let applyAllClasses = false;\n  let playerBuildersAreDirty = false;\n\n  const classesPlayerBuilderIndex =\n      classesPlayerBuilder ? PlayerIndex.ClassMapPlayerBuilderPosition : 0;\n  if (hasPlayerBuilderChanged(\n          context, classesPlayerBuilder, PlayerIndex.ClassMapPlayerBuilderPosition)) {\n    setPlayerBuilder(context, classesPlayerBuilder, PlayerIndex.ClassMapPlayerBuilderPosition);\n    playerBuildersAreDirty = true;\n  }\n\n  const stylesPlayerBuilderIndex =\n      stylesPlayerBuilder ? PlayerIndex.StyleMapPlayerBuilderPosition : 0;\n  if (hasPlayerBuilderChanged(\n          context, stylesPlayerBuilder, PlayerIndex.StyleMapPlayerBuilderPosition)) {\n    setPlayerBuilder(context, stylesPlayerBuilder, PlayerIndex.StyleMapPlayerBuilderPosition);\n    playerBuildersAreDirty = true;\n  }\n\n  // each time a string-based value pops up then it shouldn't require a deep\n  // check of what's changed.\n  if (!ignoreAllClassUpdates) {\n    if (typeof classesValue == 'string') {\n      classNames = classesValue.split(/\\s+/);\n      // this boolean is used to avoid having to create a key/value map of `true` values\n      // since a classname string implies that all those classes are added\n      applyAllClasses = true;\n    } else {\n      classNames = classesValue ? Object.keys(classesValue) : EMPTY_ARR;\n    }\n  }\n\n  const classes = (classesValue || EMPTY_OBJ) as{[key: string]: any};\n  const styleProps = stylesValue ? Object.keys(stylesValue) : EMPTY_ARR;\n  const styles = stylesValue || EMPTY_OBJ;\n\n  const classesStartIndex = styleProps.length;\n  const multiStartIndex = getMultiStartIndex(context);\n\n  let dirty = false;\n  let ctxIndex = multiStartIndex;\n\n  let propIndex = 0;\n  const propLimit = styleProps.length + classNames.length;\n\n  // the main loop here will try and figure out how the shape of the provided\n  // styles differ with respect to the context. Later if the context/styles/classes\n  // are off-balance then they will be dealt in another loop after this one\n  while (ctxIndex < context.length && propIndex < propLimit) {\n    const isClassBased = propIndex >= classesStartIndex;\n    const processValue =\n        (!isClassBased && !ignoreAllStyleUpdates) || (isClassBased && !ignoreAllClassUpdates);\n\n    // when there is a cache-hit for a string-based class then we should\n    // avoid doing any work diffing any of the changes\n    if (processValue) {\n      const adjustedPropIndex = isClassBased ? propIndex - classesStartIndex : propIndex;\n      const newProp: string =\n          isClassBased ? classNames[adjustedPropIndex] : styleProps[adjustedPropIndex];\n      const newValue: string|boolean =\n          isClassBased ? (applyAllClasses ? true : classes[newProp]) : styles[newProp];\n      const playerBuilderIndex =\n          isClassBased ? classesPlayerBuilderIndex : stylesPlayerBuilderIndex;\n\n      const prop = getProp(context, ctxIndex);\n      if (prop === newProp) {\n        const value = getValue(context, ctxIndex);\n        const flag = getPointers(context, ctxIndex);\n        setPlayerBuilderIndex(context, ctxIndex, playerBuilderIndex);\n\n        if (hasValueChanged(flag, value, newValue)) {\n          setValue(context, ctxIndex, newValue);\n          playerBuildersAreDirty = playerBuildersAreDirty || !!playerBuilderIndex;\n\n          const initialValue = getInitialValue(context, flag);\n\n          // there is no point in setting this to dirty if the previously\n          // rendered value was being referenced by the initial style (or null)\n          if (hasValueChanged(flag, initialValue, newValue)) {\n            setDirty(context, ctxIndex, true);\n            dirty = true;\n          }\n        }\n      } else {\n        const indexOfEntry = findEntryPositionByProp(context, newProp, ctxIndex);\n        if (indexOfEntry > 0) {\n          // it was found at a later point ... just swap the values\n          const valueToCompare = getValue(context, indexOfEntry);\n          const flagToCompare = getPointers(context, indexOfEntry);\n          swapMultiContextEntries(context, ctxIndex, indexOfEntry);\n          if (hasValueChanged(flagToCompare, valueToCompare, newValue)) {\n            const initialValue = getInitialValue(context, flagToCompare);\n            setValue(context, ctxIndex, newValue);\n            if (hasValueChanged(flagToCompare, initialValue, newValue)) {\n              setDirty(context, ctxIndex, true);\n              playerBuildersAreDirty = playerBuildersAreDirty || !!playerBuilderIndex;\n              dirty = true;\n            }\n          }\n        } else {\n          // we only care to do this if the insertion is in the middle\n          const newFlag = prepareInitialFlag(newProp, isClassBased, getStyleSanitizer(context));\n          playerBuildersAreDirty = playerBuildersAreDirty || !!playerBuilderIndex;\n          insertNewMultiProperty(\n              context, ctxIndex, isClassBased, newProp, newFlag, newValue, playerBuilderIndex);\n          dirty = true;\n        }\n      }\n    }\n\n    ctxIndex += StylingIndex.Size;\n    propIndex++;\n  }\n\n  // this means that there are left-over values in the context that\n  // were not included in the provided styles/classes and in this\n  // case the  goal is to \"remove\" them from the context (by nullifying)\n  while (ctxIndex < context.length) {\n    const flag = getPointers(context, ctxIndex);\n    const isClassBased = (flag & StylingFlags.Class) === StylingFlags.Class;\n    const processValue =\n        (!isClassBased && !ignoreAllStyleUpdates) || (isClassBased && !ignoreAllClassUpdates);\n    if (processValue) {\n      const value = getValue(context, ctxIndex);\n      const doRemoveValue = valueExists(value, isClassBased);\n      if (doRemoveValue) {\n        setDirty(context, ctxIndex, true);\n        setValue(context, ctxIndex, null);\n\n        // we keep the player factory the same so that the `nulled` value can\n        // be instructed into the player because removing a style and/or a class\n        // is a valid animation player instruction.\n        const playerBuilderIndex =\n            isClassBased ? classesPlayerBuilderIndex : stylesPlayerBuilderIndex;\n        setPlayerBuilderIndex(context, ctxIndex, playerBuilderIndex);\n        dirty = true;\n      }\n    }\n    ctxIndex += StylingIndex.Size;\n  }\n\n  // this means that there are left-over properties in the context that\n  // were not detected in the context during the loop above. In that\n  // case we want to add the new entries into the list\n  const sanitizer = getStyleSanitizer(context);\n  while (propIndex < propLimit) {\n    const isClassBased = propIndex >= classesStartIndex;\n    const processValue =\n        (!isClassBased && !ignoreAllStyleUpdates) || (isClassBased && !ignoreAllClassUpdates);\n    if (processValue) {\n      const adjustedPropIndex = isClassBased ? propIndex - classesStartIndex : propIndex;\n      const prop = isClassBased ? classNames[adjustedPropIndex] : styleProps[adjustedPropIndex];\n      const value: string|boolean =\n          isClassBased ? (applyAllClasses ? true : classes[prop]) : styles[prop];\n      const flag = prepareInitialFlag(prop, isClassBased, sanitizer) | StylingFlags.Dirty;\n      const playerBuilderIndex =\n          isClassBased ? classesPlayerBuilderIndex : stylesPlayerBuilderIndex;\n      context.push(flag, prop, value, playerBuilderIndex);\n      dirty = true;\n    }\n    propIndex++;\n  }\n\n  if (dirty) {\n    setContextDirty(context, true);\n  }\n\n  if (playerBuildersAreDirty) {\n    setContextPlayersDirty(context, true);\n  }\n}\n\n/**\n * Sets and resolves a single styling property/value on the provided `StylingContext` so\n * that they can be applied to the element once `renderStyleAndClassBindings` is called.\n *\n * Note that prop-level styling values are considered higher priority than any styling that\n * has been applied using `updateStylingMap`, therefore, when styling values are rendered\n * then any styles/classes that have been applied using this function will be considered first\n * (then multi values second and then initial values as a backup).\n *\n * @param context The styling context that will be updated with the\n *    newly provided style value.\n * @param index The index of the property which is being updated.\n * @param value The CSS style value that will be assigned\n */\nexport function updateStyleProp(\n    context: StylingContext, index: number,\n    input: string | boolean | null | BoundPlayerFactory<string|boolean|null>): void {\n  const singleIndex = StylingIndex.SingleStylesStartPosition + index * StylingIndex.Size;\n  const currValue = getValue(context, singleIndex);\n  const currFlag = getPointers(context, singleIndex);\n  const value: string|boolean|null = (input instanceof BoundPlayerFactory) ? input.value : input;\n\n  // didn't change ... nothing to make a note of\n  if (hasValueChanged(currFlag, currValue, value)) {\n    const isClassBased = (currFlag & StylingFlags.Class) === StylingFlags.Class;\n    const element = context[StylingIndex.ElementPosition] !as HTMLElement;\n    const playerBuilder = input instanceof BoundPlayerFactory ?\n        new ClassAndStylePlayerBuilder(\n            input as any, element, isClassBased ? BindingType.Class : BindingType.Style) :\n        null;\n    const value = (playerBuilder ? (input as BoundPlayerFactory<any>).value : input) as string |\n        boolean | null;\n    const currPlayerIndex = getPlayerBuilderIndex(context, singleIndex);\n\n    let playerBuildersAreDirty = false;\n    let playerBuilderIndex = playerBuilder ? currPlayerIndex : 0;\n    if (hasPlayerBuilderChanged(context, playerBuilder, currPlayerIndex)) {\n      const newIndex = setPlayerBuilder(context, playerBuilder, currPlayerIndex);\n      playerBuilderIndex = playerBuilder ? newIndex : 0;\n      setPlayerBuilderIndex(context, singleIndex, playerBuilderIndex);\n      playerBuildersAreDirty = true;\n    }\n\n    // the value will always get updated (even if the dirty flag is skipped)\n    setValue(context, singleIndex, value);\n    const indexForMulti = getMultiOrSingleIndex(currFlag);\n\n    // if the value is the same in the multi-area then there's no point in re-assembling\n    const valueForMulti = getValue(context, indexForMulti);\n    if (!valueForMulti || hasValueChanged(currFlag, valueForMulti, value)) {\n      let multiDirty = false;\n      let singleDirty = true;\n\n      // only when the value is set to `null` should the multi-value get flagged\n      if (!valueExists(value, isClassBased) && valueExists(valueForMulti, isClassBased)) {\n        multiDirty = true;\n        singleDirty = false;\n      }\n\n      setDirty(context, indexForMulti, multiDirty);\n      setDirty(context, singleIndex, singleDirty);\n      setContextDirty(context, true);\n    }\n\n    if (playerBuildersAreDirty) {\n      setContextPlayersDirty(context, true);\n    }\n  }\n}\n\n/**\n * This method will toggle the referenced CSS class (by the provided index)\n * within the given context.\n *\n * @param context The styling context that will be updated with the\n *    newly provided class value.\n * @param index The index of the CSS class which is being updated.\n * @param addOrRemove Whether or not to add or remove the CSS class\n */\nexport function updateClassProp(\n    context: StylingContext, index: number,\n    addOrRemove: boolean | BoundPlayerFactory<boolean>): void {\n  const adjustedIndex = index + context[StylingIndex.ClassOffsetPosition];\n  updateStyleProp(context, adjustedIndex, addOrRemove);\n}\n\n/**\n * Renders all queued styling using a renderer onto the given element.\n *\n * This function works by rendering any styles (that have been applied\n * using `updateStylingMap`) and any classes (that have been applied using\n * `updateStyleProp`) onto the provided element using the provided renderer.\n * Just before the styles/classes are rendered a final key/value style map\n * will be assembled (if `styleStore` or `classStore` are provided).\n *\n * @param lElement the element that the styles will be rendered on\n * @param context The styling context that will be used to determine\n *      what styles will be rendered\n * @param renderer the renderer that will be used to apply the styling\n * @param classesStore if provided, the updated class values will be applied\n *    to this key/value map instead of being renderered via the renderer.\n * @param stylesStore if provided, the updated style values will be applied\n *    to this key/value map instead of being renderered via the renderer.\n * @returns number the total amount of players that got queued for animation (if any)\n */\nexport function renderStyleAndClassBindings(\n    context: StylingContext, renderer: Renderer3, rootOrView: RootContext | LViewData,\n    isFirstRender: boolean, classesStore?: BindingStore | null,\n    stylesStore?: BindingStore | null): number {\n  let totalPlayersQueued = 0;\n\n  if (isContextDirty(context)) {\n    const flushPlayerBuilders: any =\n        context[StylingIndex.MasterFlagPosition] & StylingFlags.PlayerBuildersDirty;\n    const native = context[StylingIndex.ElementPosition] !;\n    const multiStartIndex = getMultiStartIndex(context);\n    const styleSanitizer = getStyleSanitizer(context);\n    const onlySingleClasses = limitToSingleClasses(context);\n\n    for (let i = StylingIndex.SingleStylesStartPosition; i < context.length;\n         i += StylingIndex.Size) {\n      // there is no point in rendering styles that have not changed on screen\n      if (isDirty(context, i)) {\n        const prop = getProp(context, i);\n        const value = getValue(context, i);\n        const flag = getPointers(context, i);\n        const playerBuilder = getPlayerBuilder(context, i);\n        const isClassBased = flag & StylingFlags.Class ? true : false;\n        const isInSingleRegion = i < multiStartIndex;\n        const readInitialValue = !isClassBased || !onlySingleClasses;\n\n        let valueToApply: string|boolean|null = value;\n\n        // VALUE DEFER CASE 1: Use a multi value instead of a null single value\n        // this check implies that a single value was removed and we\n        // should now defer to a multi value and use that (if set).\n        if (isInSingleRegion && !valueExists(valueToApply, isClassBased)) {\n          // single values ALWAYS have a reference to a multi index\n          const multiIndex = getMultiOrSingleIndex(flag);\n          valueToApply = getValue(context, multiIndex);\n        }\n\n        // VALUE DEFER CASE 2: Use the initial value if all else fails (is falsy)\n        // the initial value will always be a string or null,\n        // therefore we can safely adopt it incase there's nothing else\n        // note that this should always be a falsy check since `false` is used\n        // for both class and style comparisons (styles can't be false and false\n        // classes are turned off and should therefore defer to their initial values)\n        if (!valueExists(valueToApply, isClassBased) && readInitialValue) {\n          valueToApply = getInitialValue(context, flag);\n        }\n\n        // if the first render is true then we do not want to start applying falsy\n        // values to the DOM element's styling. Otherwise then we know there has\n        // been a change and even if it's falsy then it's removing something that\n        // was truthy before.\n        const doApplyValue = isFirstRender ? valueToApply : true;\n        if (doApplyValue) {\n          if (isClassBased) {\n            setClass(\n                native, prop, valueToApply ? true : false, renderer, classesStore, playerBuilder);\n          } else {\n            const sanitizer = (flag & StylingFlags.Sanitize) ? styleSanitizer : null;\n            setStyle(\n                native, prop, valueToApply as string | null, renderer, sanitizer, stylesStore,\n                playerBuilder);\n          }\n        }\n\n        setDirty(context, i, false);\n      }\n    }\n\n    if (flushPlayerBuilders) {\n      const rootContext =\n          Array.isArray(rootOrView) ? getRootContext(rootOrView) : rootOrView as RootContext;\n      const playerContext = getPlayerContext(context) !;\n      const playersStartIndex = playerContext[PlayerIndex.NonBuilderPlayersStart];\n      for (let i = PlayerIndex.PlayerBuildersStartPosition; i < playersStartIndex;\n           i += PlayerIndex.PlayerAndPlayerBuildersTupleSize) {\n        const builder = playerContext[i] as ClassAndStylePlayerBuilder<any>| null;\n        const playerInsertionIndex = i + PlayerIndex.PlayerOffsetPosition;\n        const oldPlayer = playerContext[playerInsertionIndex] as Player | null;\n        if (builder) {\n          const player = builder.buildPlayer(oldPlayer, isFirstRender);\n          if (player !== undefined) {\n            if (player != null) {\n              const wasQueued = addPlayerInternal(\n                  playerContext, rootContext, native as HTMLElement, player, playerInsertionIndex);\n              wasQueued && totalPlayersQueued++;\n            }\n            if (oldPlayer) {\n              oldPlayer.destroy();\n            }\n          }\n        } else if (oldPlayer) {\n          // the player builder has been removed ... therefore we should delete the associated\n          // player\n          oldPlayer.destroy();\n        }\n      }\n      setContextPlayersDirty(context, false);\n    }\n    setContextDirty(context, false);\n  }\n\n  return totalPlayersQueued;\n}\n\n/**\n * This function renders a given CSS prop/value entry using the\n * provided renderer. If a `store` value is provided then\n * that will be used a render context instead of the provided\n * renderer.\n *\n * @param native the DOM Element\n * @param prop the CSS style property that will be rendered\n * @param value the CSS style value that will be rendered\n * @param renderer\n * @param store an optional key/value map that will be used as a context to render styles on\n */\nfunction setStyle(\n    native: any, prop: string, value: string | null, renderer: Renderer3,\n    sanitizer: StyleSanitizeFn | null, store?: BindingStore | null,\n    playerBuilder?: ClassAndStylePlayerBuilder<any>| null) {\n  value = sanitizer && value ? sanitizer(prop, value) : value;\n  if (store || playerBuilder) {\n    if (store) {\n      store.setValue(prop, value);\n    }\n    if (playerBuilder) {\n      playerBuilder.setValue(prop, value);\n    }\n  } else if (value) {\n    ngDevMode && ngDevMode.rendererSetStyle++;\n    isProceduralRenderer(renderer) ?\n        renderer.setStyle(native, prop, value, RendererStyleFlags3.DashCase) :\n        native['style'].setProperty(prop, value);\n  } else {\n    ngDevMode && ngDevMode.rendererRemoveStyle++;\n    isProceduralRenderer(renderer) ?\n        renderer.removeStyle(native, prop, RendererStyleFlags3.DashCase) :\n        native['style'].removeProperty(prop);\n  }\n}\n\n/**\n * This function renders a given CSS class value using the provided\n * renderer (by adding or removing it from the provided element).\n * If a `store` value is provided then that will be used a render\n * context instead of the provided renderer.\n *\n * @param native the DOM Element\n * @param prop the CSS style property that will be rendered\n * @param value the CSS style value that will be rendered\n * @param renderer\n * @param store an optional key/value map that will be used as a context to render styles on\n */\nfunction setClass(\n    native: any, className: string, add: boolean, renderer: Renderer3, store?: BindingStore | null,\n    playerBuilder?: ClassAndStylePlayerBuilder<any>| null) {\n  if (store || playerBuilder) {\n    if (store) {\n      store.setValue(className, add);\n    }\n    if (playerBuilder) {\n      playerBuilder.setValue(className, add);\n    }\n  } else if (add) {\n    ngDevMode && ngDevMode.rendererAddClass++;\n    isProceduralRenderer(renderer) ? renderer.addClass(native, className) :\n                                     native['classList'].add(className);\n  } else {\n    ngDevMode && ngDevMode.rendererRemoveClass++;\n    isProceduralRenderer(renderer) ? renderer.removeClass(native, className) :\n                                     native['classList'].remove(className);\n  }\n}\n\nfunction setDirty(context: StylingContext, index: number, isDirtyYes: boolean) {\n  const adjustedIndex =\n      index >= StylingIndex.SingleStylesStartPosition ? (index + StylingIndex.FlagsOffset) : index;\n  if (isDirtyYes) {\n    (context[adjustedIndex] as number) |= StylingFlags.Dirty;\n  } else {\n    (context[adjustedIndex] as number) &= ~StylingFlags.Dirty;\n  }\n}\n\nfunction isDirty(context: StylingContext, index: number): boolean {\n  const adjustedIndex =\n      index >= StylingIndex.SingleStylesStartPosition ? (index + StylingIndex.FlagsOffset) : index;\n  return ((context[adjustedIndex] as number) & StylingFlags.Dirty) == StylingFlags.Dirty;\n}\n\nfunction isClassBased(context: StylingContext, index: number): boolean {\n  const adjustedIndex =\n      index >= StylingIndex.SingleStylesStartPosition ? (index + StylingIndex.FlagsOffset) : index;\n  return ((context[adjustedIndex] as number) & StylingFlags.Class) == StylingFlags.Class;\n}\n\nfunction isSanitizable(context: StylingContext, index: number): boolean {\n  const adjustedIndex =\n      index >= StylingIndex.SingleStylesStartPosition ? (index + StylingIndex.FlagsOffset) : index;\n  return ((context[adjustedIndex] as number) & StylingFlags.Sanitize) == StylingFlags.Sanitize;\n}\n\nfunction pointers(configFlag: number, staticIndex: number, dynamicIndex: number) {\n  return (configFlag & StylingFlags.BitMask) | (staticIndex << StylingFlags.BitCountSize) |\n      (dynamicIndex << (StylingIndex.BitCountSize + StylingFlags.BitCountSize));\n}\n\nfunction getInitialValue(context: StylingContext, flag: number): string|null {\n  const index = getInitialIndex(flag);\n  return context[StylingIndex.InitialStylesPosition][index] as null | string;\n}\n\nfunction getInitialIndex(flag: number): number {\n  return (flag >> StylingFlags.BitCountSize) & StylingIndex.BitMask;\n}\n\nfunction getMultiOrSingleIndex(flag: number): number {\n  const index =\n      (flag >> (StylingIndex.BitCountSize + StylingFlags.BitCountSize)) & StylingIndex.BitMask;\n  return index >= StylingIndex.SingleStylesStartPosition ? index : -1;\n}\n\nfunction getMultiStartIndex(context: StylingContext): number {\n  return getMultiOrSingleIndex(context[StylingIndex.MasterFlagPosition]) as number;\n}\n\nfunction getStyleSanitizer(context: StylingContext): StyleSanitizeFn|null {\n  return context[StylingIndex.StyleSanitizerPosition];\n}\n\nfunction setProp(context: StylingContext, index: number, prop: string) {\n  context[index + StylingIndex.PropertyOffset] = prop;\n}\n\nfunction setValue(context: StylingContext, index: number, value: string | null | boolean) {\n  context[index + StylingIndex.ValueOffset] = value;\n}\n\nfunction hasPlayerBuilderChanged(\n    context: StylingContext, builder: ClassAndStylePlayerBuilder<any>| null, index: number) {\n  const playerContext = context[StylingIndex.PlayerContext] !;\n  if (builder) {\n    if (!playerContext || index === 0) {\n      return true;\n    }\n  } else if (!playerContext) {\n    return false;\n  }\n  return playerContext[index] !== builder;\n}\n\nfunction setPlayerBuilder(\n    context: StylingContext, builder: ClassAndStylePlayerBuilder<any>| null,\n    insertionIndex: number): number {\n  let playerContext = context[StylingIndex.PlayerContext] || allocPlayerContext(context);\n  if (insertionIndex > 0) {\n    playerContext[insertionIndex] = builder;\n  } else {\n    insertionIndex = playerContext[PlayerIndex.NonBuilderPlayersStart];\n    playerContext.splice(insertionIndex, 0, builder, null);\n    playerContext[PlayerIndex.NonBuilderPlayersStart] +=\n        PlayerIndex.PlayerAndPlayerBuildersTupleSize;\n  }\n  return insertionIndex;\n}\n\nfunction setPlayerBuilderIndex(context: StylingContext, index: number, playerBuilderIndex: number) {\n  context[index + StylingIndex.PlayerBuilderIndexOffset] = playerBuilderIndex;\n}\n\nfunction getPlayerBuilderIndex(context: StylingContext, index: number): number {\n  return (context[index + StylingIndex.PlayerBuilderIndexOffset] as number) || 0;\n}\n\nfunction getPlayerBuilder(context: StylingContext, index: number): ClassAndStylePlayerBuilder<any>|\n    null {\n  const playerBuilderIndex = getPlayerBuilderIndex(context, index);\n  if (playerBuilderIndex) {\n    const playerContext = context[StylingIndex.PlayerContext];\n    if (playerContext) {\n      return playerContext[playerBuilderIndex] as ClassAndStylePlayerBuilder<any>| null;\n    }\n  }\n  return null;\n}\n\nfunction setFlag(context: StylingContext, index: number, flag: number) {\n  const adjustedIndex =\n      index === StylingIndex.MasterFlagPosition ? index : (index + StylingIndex.FlagsOffset);\n  context[adjustedIndex] = flag;\n}\n\nfunction getPointers(context: StylingContext, index: number): number {\n  const adjustedIndex =\n      index === StylingIndex.MasterFlagPosition ? index : (index + StylingIndex.FlagsOffset);\n  return context[adjustedIndex] as number;\n}\n\nfunction getValue(context: StylingContext, index: number): string|boolean|null {\n  return context[index + StylingIndex.ValueOffset] as string | boolean | null;\n}\n\nfunction getProp(context: StylingContext, index: number): string {\n  return context[index + StylingIndex.PropertyOffset] as string;\n}\n\nexport function isContextDirty(context: StylingContext): boolean {\n  return isDirty(context, StylingIndex.MasterFlagPosition);\n}\n\nexport function limitToSingleClasses(context: StylingContext) {\n  return context[StylingIndex.MasterFlagPosition] & StylingFlags.OnlyProcessSingleClasses;\n}\n\nexport function setContextDirty(context: StylingContext, isDirtyYes: boolean): void {\n  setDirty(context, StylingIndex.MasterFlagPosition, isDirtyYes);\n}\n\nexport function setContextPlayersDirty(context: StylingContext, isDirtyYes: boolean): void {\n  if (isDirtyYes) {\n    (context[StylingIndex.MasterFlagPosition] as number) |= StylingFlags.PlayerBuildersDirty;\n  } else {\n    (context[StylingIndex.MasterFlagPosition] as number) &= ~StylingFlags.PlayerBuildersDirty;\n  }\n}\n\nfunction findEntryPositionByProp(\n    context: StylingContext, prop: string, startIndex?: number): number {\n  for (let i = (startIndex || 0) + StylingIndex.PropertyOffset; i < context.length;\n       i += StylingIndex.Size) {\n    const thisProp = context[i];\n    if (thisProp == prop) {\n      return i - StylingIndex.PropertyOffset;\n    }\n  }\n  return -1;\n}\n\nfunction swapMultiContextEntries(context: StylingContext, indexA: number, indexB: number) {\n  const tmpValue = getValue(context, indexA);\n  const tmpProp = getProp(context, indexA);\n  const tmpFlag = getPointers(context, indexA);\n  const tmpPlayerBuilderIndex = getPlayerBuilderIndex(context, indexA);\n\n  let flagA = tmpFlag;\n  let flagB = getPointers(context, indexB);\n\n  const singleIndexA = getMultiOrSingleIndex(flagA);\n  if (singleIndexA >= 0) {\n    const _flag = getPointers(context, singleIndexA);\n    const _initial = getInitialIndex(_flag);\n    setFlag(context, singleIndexA, pointers(_flag, _initial, indexB));\n  }\n\n  const singleIndexB = getMultiOrSingleIndex(flagB);\n  if (singleIndexB >= 0) {\n    const _flag = getPointers(context, singleIndexB);\n    const _initial = getInitialIndex(_flag);\n    setFlag(context, singleIndexB, pointers(_flag, _initial, indexA));\n  }\n\n  setValue(context, indexA, getValue(context, indexB));\n  setProp(context, indexA, getProp(context, indexB));\n  setFlag(context, indexA, getPointers(context, indexB));\n  setPlayerBuilderIndex(context, indexA, getPlayerBuilderIndex(context, indexB));\n\n  setValue(context, indexB, tmpValue);\n  setProp(context, indexB, tmpProp);\n  setFlag(context, indexB, tmpFlag);\n  setPlayerBuilderIndex(context, indexB, tmpPlayerBuilderIndex);\n}\n\nfunction updateSinglePointerValues(context: StylingContext, indexStartPosition: number) {\n  for (let i = indexStartPosition; i < context.length; i += StylingIndex.Size) {\n    const multiFlag = getPointers(context, i);\n    const singleIndex = getMultiOrSingleIndex(multiFlag);\n    if (singleIndex > 0) {\n      const singleFlag = getPointers(context, singleIndex);\n      const initialIndexForSingle = getInitialIndex(singleFlag);\n      const flagValue = (isDirty(context, singleIndex) ? StylingFlags.Dirty : StylingFlags.None) |\n          (isClassBased(context, singleIndex) ? StylingFlags.Class : StylingFlags.None) |\n          (isSanitizable(context, singleIndex) ? StylingFlags.Sanitize : StylingFlags.None);\n      const updatedFlag = pointers(flagValue, initialIndexForSingle, i);\n      setFlag(context, singleIndex, updatedFlag);\n    }\n  }\n}\n\nfunction insertNewMultiProperty(\n    context: StylingContext, index: number, classBased: boolean, name: string, flag: number,\n    value: string | boolean, playerIndex: number): void {\n  const doShift = index < context.length;\n\n  // prop does not exist in the list, add it in\n  context.splice(\n      index, 0, flag | StylingFlags.Dirty | (classBased ? StylingFlags.Class : StylingFlags.None),\n      name, value, playerIndex);\n\n  if (doShift) {\n    // because the value was inserted midway into the array then we\n    // need to update all the shifted multi values' single value\n    // pointers to point to the newly shifted location\n    updateSinglePointerValues(context, index + StylingIndex.Size);\n  }\n}\n\nfunction valueExists(value: string | null | boolean, isClassBased?: boolean) {\n  if (isClassBased) {\n    return value ? true : false;\n  }\n  return value !== null;\n}\n\nfunction prepareInitialFlag(\n    name: string, isClassBased: boolean, sanitizer?: StyleSanitizeFn | null) {\n  if (isClassBased) {\n    return StylingFlags.Class;\n  } else if (sanitizer && sanitizer(name)) {\n    return StylingFlags.Sanitize;\n  }\n  return StylingFlags.None;\n}\n\nfunction hasValueChanged(\n    flag: number, a: string | boolean | null, b: string | boolean | null): boolean {\n  const isClassBased = flag & StylingFlags.Class;\n  const hasValues = a && b;\n  const usesSanitizer = flag & StylingFlags.Sanitize;\n  // the toString() comparison ensures that a value is checked\n  // ... otherwise (during sanitization bypassing) the === comparsion\n  // would fail since a new String() instance is created\n  if (!isClassBased && hasValues && usesSanitizer) {\n    // we know for sure we're dealing with strings at this point\n    return (a as string).toString() !== (b as string).toString();\n  }\n\n  // everything else is safe to check with a normal equality check\n  return a !== b;\n}\n\nexport class ClassAndStylePlayerBuilder<T> implements PlayerBuilder {\n  private _values: {[key: string]: string | null} = {};\n  private _dirty = false;\n  private _factory: BoundPlayerFactory<T>;\n\n  constructor(factory: PlayerFactory, private _element: HTMLElement, private _type: BindingType) {\n    this._factory = factory as any;\n  }\n\n  setValue(prop: string, value: any) {\n    if (this._values[prop] !== value) {\n      this._values[prop] = value;\n      this._dirty = true;\n    }\n  }\n\n  buildPlayer(currentPlayer: Player|null, isFirstRender: boolean): Player|undefined|null {\n    // if no values have been set here then this means the binding didn't\n    // change and therefore the binding values were not updated through\n    // `setValue` which means no new player will be provided.\n    if (this._dirty) {\n      const player = this._factory.fn(\n          this._element, this._type, this._values !, isFirstRender, currentPlayer || null);\n      this._values = {};\n      this._dirty = false;\n      return player;\n    }\n\n    return undefined;\n  }\n}\n"]}
1582
+ /**
1583
+ * Used to provide a summary of the state of the styling context.
1584
+ *
1585
+ * This is an internal interface that is only used inside of test tooling to
1586
+ * help summarize what's going on within the styling context. None of this code
1587
+ * is designed to be exported publicly and will, therefore, be tree-shaken away
1588
+ * during runtime.
1589
+ * @record
1590
+ */
1591
+ export function LogSummary() { }
1592
+ if (false) {
1593
+ /** @type {?} */
1594
+ LogSummary.prototype.name;
1595
+ /** @type {?} */
1596
+ LogSummary.prototype.staticIndex;
1597
+ /** @type {?} */
1598
+ LogSummary.prototype.dynamicIndex;
1599
+ /** @type {?} */
1600
+ LogSummary.prototype.value;
1601
+ /** @type {?} */
1602
+ LogSummary.prototype.flags;
1603
+ }
1604
+ /**
1605
+ * @param {?} source
1606
+ * @param {?=} index
1607
+ * @return {?}
1608
+ */
1609
+ export function generateConfigSummary(source, index) {
1610
+ /** @type {?} */
1611
+ let flag;
1612
+ /** @type {?} */
1613
+ let name = 'config value for ';
1614
+ if (Array.isArray(source)) {
1615
+ if (index) {
1616
+ name += 'index: ' + index;
1617
+ }
1618
+ else {
1619
+ name += 'master config';
1620
+ }
1621
+ index = index || 0 /* MasterFlagPosition */;
1622
+ flag = (/** @type {?} */ (source[index]));
1623
+ }
1624
+ else {
1625
+ flag = source;
1626
+ name += 'index: ' + flag;
1627
+ }
1628
+ /** @type {?} */
1629
+ const dynamicIndex = getMultiOrSingleIndex(flag);
1630
+ /** @type {?} */
1631
+ const staticIndex = getInitialIndex(flag);
1632
+ return {
1633
+ name,
1634
+ staticIndex,
1635
+ dynamicIndex,
1636
+ value: flag,
1637
+ flags: {
1638
+ dirty: flag & 1 /* Dirty */ ? true : false,
1639
+ class: flag & 2 /* Class */ ? true : false,
1640
+ sanitize: flag & 4 /* Sanitize */ ? true : false,
1641
+ playerBuildersDirty: flag & 8 /* PlayerBuildersDirty */ ? true : false,
1642
+ onlyProcessSingleClasses: flag & 16 /* OnlyProcessSingleClasses */ ? true : false,
1643
+ bindingAllocationLocked: flag & 32 /* BindingAllocationLocked */ ? true : false,
1644
+ }
1645
+ };
1646
+ }
1647
+ /**
1648
+ * @param {?} context
1649
+ * @param {?} index
1650
+ * @return {?}
1651
+ */
1652
+ export function getDirectiveIndexFromEntry(context, index) {
1653
+ /** @type {?} */
1654
+ const value = (/** @type {?} */ (context[index + 3 /* PlayerBuilderIndexOffset */]));
1655
+ return value & 65535 /* BitMask */;
1656
+ }
1657
+ /**
1658
+ * @param {?} context
1659
+ * @param {?} directive
1660
+ * @return {?}
1661
+ */
1662
+ function getDirectiveIndexFromRegistry(context, directive) {
1663
+ /** @type {?} */
1664
+ const index = getDirectiveRegistryValuesIndexOf(context[1 /* DirectiveRegistryPosition */], directive);
1665
+ ngDevMode &&
1666
+ assertNotEqual(index, -1, `The provided directive ${directive} has not been allocated to the element\'s style/class bindings`);
1667
+ return index > 0 ? index / 4 /* Size */ : 0;
1668
+ // return index / DirectiveRegistryValuesIndex.Size;
1669
+ }
1670
+ /**
1671
+ * @param {?} directives
1672
+ * @param {?} directive
1673
+ * @return {?}
1674
+ */
1675
+ function getDirectiveRegistryValuesIndexOf(directives, directive) {
1676
+ for (let i = 0; i < directives.length; i += 4 /* Size */) {
1677
+ if (directives[i] === directive) {
1678
+ return i;
1679
+ }
1680
+ }
1681
+ return -1;
1682
+ }
1683
+ /**
1684
+ * @param {?} keyValues
1685
+ * @param {?} key
1686
+ * @return {?}
1687
+ */
1688
+ function getInitialStylingValuesIndexOf(keyValues, key) {
1689
+ for (let i = 1 /* KeyValueStartPosition */; i < keyValues.length; i += 2 /* Size */) {
1690
+ if (keyValues[i] === key)
1691
+ return i;
1692
+ }
1693
+ return -1;
1694
+ }
1695
+ /**
1696
+ * @param {?} a
1697
+ * @param {?} b
1698
+ * @return {?}
1699
+ */
1700
+ export function compareLogSummaries(a, b) {
1701
+ /** @type {?} */
1702
+ const log = [];
1703
+ /** @type {?} */
1704
+ const diffs = [];
1705
+ diffSummaryValues(diffs, 'staticIndex', 'staticIndex', a, b);
1706
+ diffSummaryValues(diffs, 'dynamicIndex', 'dynamicIndex', a, b);
1707
+ Object.keys(a.flags).forEach(name => { diffSummaryValues(diffs, 'flags.' + name, name, a.flags, b.flags); });
1708
+ if (diffs.length) {
1709
+ log.push('Log Summaries for:');
1710
+ log.push(' A: ' + a.name);
1711
+ log.push(' B: ' + b.name);
1712
+ log.push('\n Differ in the following way (A !== B):');
1713
+ diffs.forEach(result => {
1714
+ const [name, aVal, bVal] = result;
1715
+ log.push(' => ' + name);
1716
+ log.push(' => ' + aVal + ' !== ' + bVal + '\n');
1717
+ });
1718
+ }
1719
+ return log;
1720
+ }
1721
+ /**
1722
+ * @param {?} result
1723
+ * @param {?} name
1724
+ * @param {?} prop
1725
+ * @param {?} a
1726
+ * @param {?} b
1727
+ * @return {?}
1728
+ */
1729
+ function diffSummaryValues(result, name, prop, a, b) {
1730
+ /** @type {?} */
1731
+ const aVal = a[prop];
1732
+ /** @type {?} */
1733
+ const bVal = b[prop];
1734
+ if (aVal !== bVal) {
1735
+ result.push([name, aVal, bVal]);
1736
+ }
1737
+ }
1738
+ /**
1739
+ * @param {?} context
1740
+ * @param {?} directiveIndex
1741
+ * @param {?} offset
1742
+ * @param {?} isClassBased
1743
+ * @return {?}
1744
+ */
1745
+ function getSinglePropIndexValue(context, directiveIndex, offset, isClassBased) {
1746
+ /** @type {?} */
1747
+ const singlePropOffsetRegistryIndex = (/** @type {?} */ (context[1 /* DirectiveRegistryPosition */][(directiveIndex * 4 /* Size */) +
1748
+ 1 /* SinglePropValuesIndexOffset */]));
1749
+ /** @type {?} */
1750
+ const offsets = context[4 /* SinglePropOffsetPositions */];
1751
+ /** @type {?} */
1752
+ const indexForOffset = singlePropOffsetRegistryIndex +
1753
+ 2 /* ValueStartPosition */ +
1754
+ (isClassBased ?
1755
+ offsets[singlePropOffsetRegistryIndex + 0 /* StylesCountPosition */] :
1756
+ 0) +
1757
+ offset;
1758
+ return offsets[indexForOffset];
1759
+ }
1760
+ /**
1761
+ * @param {?} context
1762
+ * @param {?} directiveIndex
1763
+ * @return {?}
1764
+ */
1765
+ function getStyleSanitizer(context, directiveIndex) {
1766
+ /** @type {?} */
1767
+ const dirs = context[1 /* DirectiveRegistryPosition */];
1768
+ /** @type {?} */
1769
+ const value = dirs[directiveIndex * 4 /* Size */ +
1770
+ 3 /* StyleSanitizerOffset */] ||
1771
+ dirs[3 /* StyleSanitizerOffset */] || null;
1772
+ return (/** @type {?} */ (value));
1773
+ }
1774
+ /**
1775
+ * @param {?} context
1776
+ * @param {?} directiveIndex
1777
+ * @return {?}
1778
+ */
1779
+ function isDirectiveDirty(context, directiveIndex) {
1780
+ /** @type {?} */
1781
+ const dirs = context[1 /* DirectiveRegistryPosition */];
1782
+ return (/** @type {?} */ (dirs[directiveIndex * 4 /* Size */ +
1783
+ 2 /* DirtyFlagOffset */]));
1784
+ }
1785
+ /**
1786
+ * @param {?} context
1787
+ * @param {?} directiveIndex
1788
+ * @param {?} dirtyYes
1789
+ * @return {?}
1790
+ */
1791
+ function setDirectiveDirty(context, directiveIndex, dirtyYes) {
1792
+ /** @type {?} */
1793
+ const dirs = context[1 /* DirectiveRegistryPosition */];
1794
+ dirs[directiveIndex * 4 /* Size */ +
1795
+ 2 /* DirtyFlagOffset */] = dirtyYes;
1796
+ }
1797
+ /**
1798
+ * @param {?} currentValue
1799
+ * @param {?} newValue
1800
+ * @param {?} currentDirectiveOwner
1801
+ * @param {?} newDirectiveOwner
1802
+ * @return {?}
1803
+ */
1804
+ function allowValueChange(currentValue, newValue, currentDirectiveOwner, newDirectiveOwner) {
1805
+ // the code below relies the importance of directive's being tied to their
1806
+ // index value. The index values for each directive are derived from being
1807
+ // registered into the styling context directive registry. The most important
1808
+ // directive is the parent component directive (the template) and each directive
1809
+ // that is added after is considered less important than the previous entry. This
1810
+ // prioritization of directives enables the styling algorithm to decide if a style
1811
+ // or class should be allowed to be updated/replaced incase an earlier directive
1812
+ // already wrote to the exact same style-property or className value. In other words
1813
+ // ... this decides what to do if and when there is a collision.
1814
+ if (currentValue) {
1815
+ if (newValue) {
1816
+ // if a directive index is lower than it always has priority over the
1817
+ // previous directive's value...
1818
+ return newDirectiveOwner <= currentDirectiveOwner;
1819
+ }
1820
+ else {
1821
+ // only write a null value incase it's the same owner writing it.
1822
+ // this avoids having a higher-priority directive write to null
1823
+ // only to have a lesser-priority directive change right to a
1824
+ // non-null value immediately afterwards.
1825
+ return currentDirectiveOwner === newDirectiveOwner;
1826
+ }
1827
+ }
1828
+ return true;
1829
+ }
1830
+ /**
1831
+ * This function is only designed to be called for `[class]` bindings when
1832
+ * `[ngClass]` (or something that uses `class` as an input) is present. Once
1833
+ * directive host bindings fully work for `[class]` and `[style]` inputs
1834
+ * then this can be deleted.
1835
+ * @param {?} context
1836
+ * @return {?}
1837
+ */
1838
+ export function getInitialClassNameValue(context) {
1839
+ /** @type {?} */
1840
+ let className = (/** @type {?} */ (context[6 /* CachedClassValueOrInitialClassString */]));
1841
+ if (className == null) {
1842
+ className = '';
1843
+ /** @type {?} */
1844
+ const initialClassValues = context[3 /* InitialClassValuesPosition */];
1845
+ for (let i = 1 /* KeyValueStartPosition */; i < initialClassValues.length; i += 2 /* Size */) {
1846
+ /** @type {?} */
1847
+ const isPresent = initialClassValues[i + 1];
1848
+ if (isPresent) {
1849
+ className += (className.length ? ' ' : '') + initialClassValues[i];
1850
+ }
1851
+ }
1852
+ context[6 /* CachedClassValueOrInitialClassString */] = className;
1853
+ }
1854
+ return className;
1855
+ }
1856
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"class_and_style_bindings.js","sourceRoot":"../../","sources":["packages/core/src/render3/styling/class_and_style_bindings.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n* @license\n* Copyright Google Inc. All Rights Reserved.\n*\n* Use of this source code is governed by an MIT-style license that can be\n* found in the LICENSE file at https://angular.io/license\n*/\nimport {StyleSanitizeFn} from '../../sanitization/style_sanitizer';\nimport {assertNotEqual} from '../assert';\nimport {EMPTY_ARRAY, EMPTY_OBJ} from '../empty';\nimport {AttributeMarker, TAttributes} from '../interfaces/node';\nimport {BindingStore, BindingType, Player, PlayerBuilder, PlayerFactory, PlayerIndex} from '../interfaces/player';\nimport {RElement, Renderer3, RendererStyleFlags3, isProceduralRenderer} from '../interfaces/renderer';\nimport {DirectiveOwnerAndPlayerBuilderIndex, DirectiveRegistryValues, DirectiveRegistryValuesIndex, InitialStylingValues, InitialStylingValuesIndex, SinglePropOffsetValues, SinglePropOffsetValuesIndex, StylingContext, StylingFlags, StylingIndex} from '../interfaces/styling';\nimport {LView, RootContext} from '../interfaces/view';\nimport {NO_CHANGE} from '../tokens';\nimport {getRootContext} from '../util';\n\nimport {BoundPlayerFactory} from './player_factory';\nimport {addPlayerInternal, allocPlayerContext, createEmptyStylingContext, getPlayerContext} from './util';\n\n\n/**\n * This file includes the code to power all styling-binding operations in Angular.\n *\n * These include:\n * [style]=\"myStyleObj\"\n * [class]=\"myClassObj\"\n * [style.prop]=\"myPropValue\"\n * [class.name]=\"myClassValue\"\n *\n * There are many different ways in which these functions below are called. Please see\n * `interfaces/styles.ts` to get a better idea of how the styling algorithm works.\n */\n\n\n\n/**\n * Creates a new StylingContext an fills it with the provided static styling attribute values.\n */\nexport function initializeStaticContext(attrs: TAttributes) {\n  const context = createEmptyStylingContext();\n  const initialClasses: InitialStylingValues = context[StylingIndex.InitialClassValuesPosition] =\n      [null];\n  const initialStyles: InitialStylingValues = context[StylingIndex.InitialStyleValuesPosition] =\n      [null];\n\n  // The attributes array has marker values (numbers) indicating what the subsequent\n  // values represent. When we encounter a number, we set the mode to that type of attribute.\n  let mode = -1;\n  for (let i = 0; i < attrs.length; i++) {\n    const attr = attrs[i];\n    if (typeof attr == 'number') {\n      mode = attr;\n    } else if (mode === AttributeMarker.Styles) {\n      initialStyles.push(attr as string, attrs[++i] as string);\n    } else if (mode === AttributeMarker.Classes) {\n      initialClasses.push(attr as string, true);\n    } else if (mode === AttributeMarker.SelectOnly) {\n      break;\n    }\n  }\n\n  return context;\n}\n\n/**\n * Designed to update an existing styling context with new static styling\n * data (classes and styles).\n *\n * @param context the existing styling context\n * @param attrs an array of new static styling attributes that will be\n *              assigned to the context\n * @param directive the directive instance with which static data is associated with.\n */\nexport function patchContextWithStaticAttrs(\n    context: StylingContext, attrs: TAttributes, directive: any): void {\n  // If the styling context has already been patched with the given directive's bindings,\n  // then there is no point in doing it again. The reason why this may happen (the directive\n  // styling being patched twice) is because the `stylingBinding` function is called each time\n  // an element is created (both within a template function and within directive host bindings).\n  const directives = context[StylingIndex.DirectiveRegistryPosition];\n  if (getDirectiveRegistryValuesIndexOf(directives, directive) == -1) {\n    // this is a new directive which we have not seen yet.\n    directives.push(directive, -1, false, null);\n\n    let initialClasses: InitialStylingValues|null = null;\n    let initialStyles: InitialStylingValues|null = null;\n\n    let mode = -1;\n    for (let i = 0; i < attrs.length; i++) {\n      const attr = attrs[i];\n      if (typeof attr == 'number') {\n        mode = attr;\n      } else if (mode == AttributeMarker.Classes) {\n        initialClasses = initialClasses || context[StylingIndex.InitialClassValuesPosition];\n        patchInitialStylingValue(initialClasses, attr, true);\n      } else if (mode == AttributeMarker.Styles) {\n        initialStyles = initialStyles || context[StylingIndex.InitialStyleValuesPosition];\n        patchInitialStylingValue(initialStyles, attr, attrs[++i]);\n      }\n    }\n  }\n}\n\n/**\n * Designed to add a style or class value into the existing set of initial styles.\n *\n * The function will search and figure out if a style/class value is already present\n * within the provided initial styling array. If and when a style/class value is not\n * present (or if it's value is falsy) then it will be inserted/updated in the list\n * of initial styling values.\n */\nfunction patchInitialStylingValue(\n    initialStyling: InitialStylingValues, prop: string, value: any): void {\n  // Even values are keys; Odd numbers are values; Search keys only\n  for (let i = InitialStylingValuesIndex.KeyValueStartPosition; i < initialStyling.length;) {\n    const key = initialStyling[i];\n    if (key === prop) {\n      const existingValue = initialStyling[i + InitialStylingValuesIndex.ValueOffset];\n\n      // If there is no previous style value (when `null`) or no previous class\n      // applied (when `false`) then we update the the newly given value.\n      if (existingValue == null || existingValue == false) {\n        initialStyling[i + InitialStylingValuesIndex.ValueOffset] = value;\n      }\n      return;\n    }\n    i = i + InitialStylingValuesIndex.Size;\n  }\n  // We did not find existing key, add a new one.\n  initialStyling.push(prop, value);\n}\n\n/**\n * Runs through the initial styling data present in the context and renders\n * them via the renderer on the element.\n */\nexport function renderInitialStylesAndClasses(\n    element: RElement, context: StylingContext, renderer: Renderer3) {\n  const initialClasses = context[StylingIndex.InitialClassValuesPosition];\n  renderInitialStylingValues(element, renderer, initialClasses, true);\n\n  const initialStyles = context[StylingIndex.InitialStyleValuesPosition];\n  renderInitialStylingValues(element, renderer, initialStyles, false);\n}\n\n/**\n * This is a helper function designed to render each entry present within the\n * provided list of initialStylingValues.\n */\nfunction renderInitialStylingValues(\n    element: RElement, renderer: Renderer3, initialStylingValues: InitialStylingValues,\n    isEntryClassBased: boolean) {\n  for (let i = InitialStylingValuesIndex.KeyValueStartPosition; i < initialStylingValues.length;\n       i += InitialStylingValuesIndex.Size) {\n    const value = initialStylingValues[i + InitialStylingValuesIndex.ValueOffset];\n    if (value) {\n      if (isEntryClassBased) {\n        setClass(\n            element, initialStylingValues[i + InitialStylingValuesIndex.PropOffset] as string, true,\n            renderer, null);\n      } else {\n        setStyle(\n            element, initialStylingValues[i + InitialStylingValuesIndex.PropOffset] as string,\n            value as string, renderer, null);\n      }\n    }\n  }\n}\n\nexport function allowNewBindingsForStylingContext(context: StylingContext): boolean {\n  return (context[StylingIndex.MasterFlagPosition] & StylingFlags.BindingAllocationLocked) === 0;\n}\n\n/**\n * Adds in new binding values to a styling context.\n *\n * If a directive value is provided then all provided class/style binding names will\n * reference the provided directive.\n *\n * @param context the existing styling context\n * @param directiveRef the directive that the new bindings will reference\n * @param classBindingNames an array of class binding names that will be added to the context\n * @param styleBindingNames an array of style binding names that will be added to the context\n * @param styleSanitizer an optional sanitizer that handle all sanitization on for each of\n *    the bindings added to the context. Note that if a directive is provided then the sanitizer\n *    instance will only be active if and when the directive updates the bindings that it owns.\n */\nexport function updateContextWithBindings(\n    context: StylingContext, directiveRef: any | null, classBindingNames?: string[] | null,\n    styleBindingNames?: string[] | null, styleSanitizer?: StyleSanitizeFn | null,\n    onlyProcessSingleClasses?: boolean) {\n  if (context[StylingIndex.MasterFlagPosition] & StylingFlags.BindingAllocationLocked) return;\n\n  // this means the context has already been patched with the directive's bindings\n  const directiveIndex = findOrPatchDirectiveIntoRegistry(context, directiveRef, styleSanitizer);\n  if (directiveIndex === -1) {\n    // this means the directive has already been patched in ... No point in doing anything\n    return;\n  }\n\n  // there are alot of variables being used below to track where in the context the new\n  // binding values will be placed. Because the context consists of multiple types of\n  // entries (single classes/styles and multi classes/styles) alot of the index positions\n  // need to be computed ahead of time and the context needs to be extended before the values\n  // are inserted in.\n  const singlePropOffsetValues = context[StylingIndex.SinglePropOffsetPositions];\n  const totalCurrentClassBindings =\n      singlePropOffsetValues[SinglePropOffsetValuesIndex.ClassesCountPosition];\n  const totalCurrentStyleBindings =\n      singlePropOffsetValues[SinglePropOffsetValuesIndex.StylesCountPosition];\n\n  const classesOffset = totalCurrentClassBindings * StylingIndex.Size;\n  const stylesOffset = totalCurrentStyleBindings * StylingIndex.Size;\n\n  const singleStylesStartIndex = StylingIndex.SingleStylesStartPosition;\n  let singleClassesStartIndex = singleStylesStartIndex + stylesOffset;\n  let multiStylesStartIndex = singleClassesStartIndex + classesOffset;\n  let multiClassesStartIndex = multiStylesStartIndex + stylesOffset;\n\n  // because we're inserting more bindings into the context, this means that the\n  // binding values need to be referenced the singlePropOffsetValues array so that\n  // the template/directive can easily find them inside of the `elementStyleProp`\n  // and the `elementClassProp` functions without iterating through the entire context.\n  // The first step to setting up these reference points is to mark how many bindings\n  // are being added. Even if these bindings already exist in the context, the directive\n  // or template code will still call them unknowingly. Therefore the total values need\n  // to be registered so that we know how many bindings are assigned to each directive.\n  const currentSinglePropsLength = singlePropOffsetValues.length;\n  singlePropOffsetValues.push(\n      styleBindingNames ? styleBindingNames.length : 0,\n      classBindingNames ? classBindingNames.length : 0);\n\n  // the code below will check to see if a new style binding already exists in the context\n  // if so then there is no point in inserting it into the context again. Whether or not it\n  // exists the styling offset code will now know exactly where it is\n  let insertionOffset = 0;\n  const filteredStyleBindingNames: string[] = [];\n  if (styleBindingNames && styleBindingNames.length) {\n    for (let i = 0; i < styleBindingNames.length; i++) {\n      const name = styleBindingNames[i];\n      let singlePropIndex =\n          getMatchingBindingIndex(context, name, singleStylesStartIndex, singleClassesStartIndex);\n      if (singlePropIndex == -1) {\n        singlePropIndex = singleClassesStartIndex + insertionOffset;\n        insertionOffset += StylingIndex.Size;\n        filteredStyleBindingNames.push(name);\n      }\n      singlePropOffsetValues.push(singlePropIndex);\n    }\n  }\n\n  // just like with the style binding loop above, the new class bindings get the same treatment...\n  const filteredClassBindingNames: string[] = [];\n  if (classBindingNames && classBindingNames.length) {\n    for (let i = 0; i < classBindingNames.length; i++) {\n      const name = classBindingNames[i];\n      let singlePropIndex =\n          getMatchingBindingIndex(context, name, singleClassesStartIndex, multiStylesStartIndex);\n      if (singlePropIndex == -1) {\n        singlePropIndex = multiStylesStartIndex + insertionOffset;\n        insertionOffset += StylingIndex.Size;\n        filteredClassBindingNames.push(name);\n      } else {\n        singlePropIndex += filteredStyleBindingNames.length * StylingIndex.Size;\n      }\n      singlePropOffsetValues.push(singlePropIndex);\n    }\n  }\n\n  // because new styles are being inserted, this means the existing collection of style offset\n  // index values are incorrect (they point to the wrong values). The code below will run through\n  // the entire offset array and update the existing set of index values to point to their new\n  // locations while taking the new binding values into consideration.\n  let i = SinglePropOffsetValuesIndex.ValueStartPosition;\n  if (filteredStyleBindingNames.length) {\n    while (i < currentSinglePropsLength) {\n      const totalStyles =\n          singlePropOffsetValues[i + SinglePropOffsetValuesIndex.StylesCountPosition];\n      const totalClasses =\n          singlePropOffsetValues[i + SinglePropOffsetValuesIndex.ClassesCountPosition];\n      if (totalClasses) {\n        const start = i + SinglePropOffsetValuesIndex.ValueStartPosition + totalStyles;\n        for (let j = start; j < start + totalClasses; j++) {\n          singlePropOffsetValues[j] += filteredStyleBindingNames.length * StylingIndex.Size;\n        }\n      }\n\n      const total = totalStyles + totalClasses;\n      i += SinglePropOffsetValuesIndex.ValueStartPosition + total;\n    }\n  }\n\n  const totalNewEntries = filteredClassBindingNames.length + filteredStyleBindingNames.length;\n\n  // in the event that there are new style values being inserted, all existing class and style\n  // bindings need to have their pointer values offsetted with the new amount of space that is\n  // used for the new style/class bindings.\n  for (let i = singleStylesStartIndex; i < context.length; i += StylingIndex.Size) {\n    const isMultiBased = i >= multiStylesStartIndex;\n    const isClassBased = i >= (isMultiBased ? multiClassesStartIndex : singleClassesStartIndex);\n    const flag = getPointers(context, i);\n    const staticIndex = getInitialIndex(flag);\n    let singleOrMultiIndex = getMultiOrSingleIndex(flag);\n    if (isMultiBased) {\n      singleOrMultiIndex +=\n          isClassBased ? (filteredStyleBindingNames.length * StylingIndex.Size) : 0;\n    } else {\n      singleOrMultiIndex += (totalNewEntries * StylingIndex.Size) +\n          ((isClassBased ? filteredStyleBindingNames.length : 0) * StylingIndex.Size);\n    }\n    setFlag(context, i, pointers(flag, staticIndex, singleOrMultiIndex));\n  }\n\n  // this is where we make space in the context for the new style bindings\n  for (let i = 0; i < filteredStyleBindingNames.length * StylingIndex.Size; i++) {\n    context.splice(multiClassesStartIndex, 0, null);\n    context.splice(singleClassesStartIndex, 0, null);\n    singleClassesStartIndex++;\n    multiStylesStartIndex++;\n    multiClassesStartIndex += 2;  // both single + multi slots were inserted\n  }\n\n  // this is where we make space in the context for the new class bindings\n  for (let i = 0; i < filteredClassBindingNames.length * StylingIndex.Size; i++) {\n    context.splice(multiStylesStartIndex, 0, null);\n    context.push(null);\n    multiStylesStartIndex++;\n    multiClassesStartIndex++;\n  }\n\n  const initialClasses = context[StylingIndex.InitialClassValuesPosition];\n  const initialStyles = context[StylingIndex.InitialStyleValuesPosition];\n\n  // the code below will insert each new entry into the context and assign the appropriate\n  // flags and index values to them. It's important this runs at the end of this function\n  // because the context, property offset and index values have all been computed just before.\n  for (let i = 0; i < totalNewEntries; i++) {\n    const entryIsClassBased = i >= filteredStyleBindingNames.length;\n    const adjustedIndex = entryIsClassBased ? (i - filteredStyleBindingNames.length) : i;\n    const propName = entryIsClassBased ? filteredClassBindingNames[adjustedIndex] :\n                                         filteredStyleBindingNames[adjustedIndex];\n\n    let multiIndex, singleIndex;\n    if (entryIsClassBased) {\n      multiIndex = multiClassesStartIndex +\n          ((totalCurrentClassBindings + adjustedIndex) * StylingIndex.Size);\n      singleIndex = singleClassesStartIndex +\n          ((totalCurrentClassBindings + adjustedIndex) * StylingIndex.Size);\n    } else {\n      multiIndex =\n          multiStylesStartIndex + ((totalCurrentStyleBindings + adjustedIndex) * StylingIndex.Size);\n      singleIndex = singleStylesStartIndex +\n          ((totalCurrentStyleBindings + adjustedIndex) * StylingIndex.Size);\n    }\n\n    // if a property is not found in the initial style values list then it\n    // is ALWAYS added incase a follow-up directive introduces the same initial\n    // style/class value later on.\n    let initialValuesToLookup = entryIsClassBased ? initialClasses : initialStyles;\n    let indexForInitial = getInitialStylingValuesIndexOf(initialValuesToLookup, propName);\n    if (indexForInitial === -1) {\n      indexForInitial = initialValuesToLookup.length + InitialStylingValuesIndex.ValueOffset;\n      initialValuesToLookup.push(propName, entryIsClassBased ? false : null);\n    } else {\n      indexForInitial += InitialStylingValuesIndex.ValueOffset;\n    }\n\n    const initialFlag =\n        prepareInitialFlag(context, propName, entryIsClassBased, styleSanitizer || null);\n\n    setFlag(context, singleIndex, pointers(initialFlag, indexForInitial, multiIndex));\n    setProp(context, singleIndex, propName);\n    setValue(context, singleIndex, null);\n    setPlayerBuilderIndex(context, singleIndex, 0, directiveIndex);\n\n    setFlag(context, multiIndex, pointers(initialFlag, indexForInitial, singleIndex));\n    setProp(context, multiIndex, propName);\n    setValue(context, multiIndex, null);\n    setPlayerBuilderIndex(context, multiIndex, 0, directiveIndex);\n  }\n\n  // the total classes/style values are updated so the next time the context is patched\n  // additional style/class bindings from another directive then it knows exactly where\n  // to insert them in the context\n  singlePropOffsetValues[SinglePropOffsetValuesIndex.ClassesCountPosition] =\n      totalCurrentClassBindings + filteredClassBindingNames.length;\n  singlePropOffsetValues[SinglePropOffsetValuesIndex.StylesCountPosition] =\n      totalCurrentStyleBindings + filteredStyleBindingNames.length;\n\n  // there is no initial value flag for the master index since it doesn't\n  // reference an initial style value\n  const masterFlag = pointers(0, 0, multiStylesStartIndex) |\n      (onlyProcessSingleClasses ? StylingFlags.OnlyProcessSingleClasses : 0);\n  setFlag(context, StylingIndex.MasterFlagPosition, masterFlag);\n}\n\n/**\n * Searches through the existing registry of directives\n */\nfunction findOrPatchDirectiveIntoRegistry(\n    context: StylingContext, directiveRef: any, styleSanitizer?: StyleSanitizeFn | null) {\n  const directiveRefs = context[StylingIndex.DirectiveRegistryPosition];\n  const nextOffsetInsertionIndex = context[StylingIndex.SinglePropOffsetPositions].length;\n\n  let directiveIndex: number;\n  const detectedIndex = getDirectiveRegistryValuesIndexOf(directiveRefs, directiveRef);\n\n  if (detectedIndex === -1) {\n    directiveIndex = directiveRefs.length / DirectiveRegistryValuesIndex.Size;\n    directiveRefs.push(directiveRef, nextOffsetInsertionIndex, false, styleSanitizer || null);\n  } else {\n    const singlePropStartPosition =\n        detectedIndex + DirectiveRegistryValuesIndex.SinglePropValuesIndexOffset;\n    if (directiveRefs[singlePropStartPosition] ! >= 0) {\n      // the directive has already been patched into the context\n      return -1;\n    }\n\n    directiveIndex = detectedIndex / DirectiveRegistryValuesIndex.Size;\n\n    // because the directive already existed this means that it was set during elementHostAttrs or\n    // elementStart which means that the binding values were not here. Therefore, the values below\n    // need to be applied so that single class and style properties can be assigned later.\n    const singlePropPositionIndex =\n        detectedIndex + DirectiveRegistryValuesIndex.SinglePropValuesIndexOffset;\n    directiveRefs[singlePropPositionIndex] = nextOffsetInsertionIndex;\n\n    // the sanitizer is also apart of the binding process and will be used when bindings are\n    // applied.\n    const styleSanitizerIndex = detectedIndex + DirectiveRegistryValuesIndex.StyleSanitizerOffset;\n    directiveRefs[styleSanitizerIndex] = styleSanitizer || null;\n  }\n\n  return directiveIndex;\n}\n\nfunction getMatchingBindingIndex(\n    context: StylingContext, bindingName: string, start: number, end: number) {\n  for (let j = start; j < end; j += StylingIndex.Size) {\n    if (getProp(context, j) === bindingName) return j;\n  }\n  return -1;\n}\n\n/**\n * Sets and resolves all `multi` styling on an `StylingContext` so that they can be\n * applied to the element once `renderStyling` is called.\n *\n * All missing styles/class (any values that are not provided in the new `styles`\n * or `classes` params) will resolve to `null` within their respective positions\n * in the context.\n *\n * @param context The styling context that will be updated with the\n *    newly provided style values.\n * @param classesInput The key/value map of CSS class names that will be used for the update.\n * @param stylesInput The key/value map of CSS styles that will be used for the update.\n */\nexport function updateStylingMap(\n    context: StylingContext, classesInput: {[key: string]: any} | string |\n        BoundPlayerFactory<null|string|{[key: string]: any}>| NO_CHANGE | null,\n    stylesInput?: {[key: string]: any} | BoundPlayerFactory<null|{[key: string]: any}>| NO_CHANGE |\n        null,\n    directiveRef?: any): void {\n  stylesInput = stylesInput || null;\n\n  const directiveIndex = getDirectiveIndexFromRegistry(context, directiveRef || null);\n  const element = context[StylingIndex.ElementPosition] !as HTMLElement;\n  const classesPlayerBuilder = classesInput instanceof BoundPlayerFactory ?\n      new ClassAndStylePlayerBuilder(classesInput as any, element, BindingType.Class) :\n      null;\n  const stylesPlayerBuilder = stylesInput instanceof BoundPlayerFactory ?\n      new ClassAndStylePlayerBuilder(stylesInput as any, element, BindingType.Style) :\n      null;\n\n  const classesValue = classesPlayerBuilder ?\n      (classesInput as BoundPlayerFactory<{[key: string]: any}|string>) !.value :\n      classesInput;\n  const stylesValue = stylesPlayerBuilder ? stylesInput !.value : stylesInput;\n  // early exit (this is what's done to avoid using ctx.bind() to cache the value)\n  const ignoreAllClassUpdates = limitToSingleClasses(context) || classesValue === NO_CHANGE ||\n      classesValue === context[StylingIndex.CachedClassValueOrInitialClassString];\n  const ignoreAllStyleUpdates =\n      stylesValue === NO_CHANGE || stylesValue === context[StylingIndex.CachedStyleValue];\n  if (ignoreAllClassUpdates && ignoreAllStyleUpdates) return;\n\n  context[StylingIndex.CachedClassValueOrInitialClassString] = classesValue;\n  context[StylingIndex.CachedStyleValue] = stylesValue;\n\n  let classNames: string[] = EMPTY_ARRAY;\n  let applyAllClasses = false;\n  let playerBuildersAreDirty = false;\n\n  const classesPlayerBuilderIndex =\n      classesPlayerBuilder ? PlayerIndex.ClassMapPlayerBuilderPosition : 0;\n  if (hasPlayerBuilderChanged(\n          context, classesPlayerBuilder, PlayerIndex.ClassMapPlayerBuilderPosition)) {\n    setPlayerBuilder(context, classesPlayerBuilder, PlayerIndex.ClassMapPlayerBuilderPosition);\n    playerBuildersAreDirty = true;\n  }\n\n  const stylesPlayerBuilderIndex =\n      stylesPlayerBuilder ? PlayerIndex.StyleMapPlayerBuilderPosition : 0;\n  if (hasPlayerBuilderChanged(\n          context, stylesPlayerBuilder, PlayerIndex.StyleMapPlayerBuilderPosition)) {\n    setPlayerBuilder(context, stylesPlayerBuilder, PlayerIndex.StyleMapPlayerBuilderPosition);\n    playerBuildersAreDirty = true;\n  }\n\n  // each time a string-based value pops up then it shouldn't require a deep\n  // check of what's changed.\n  if (!ignoreAllClassUpdates) {\n    if (typeof classesValue == 'string') {\n      classNames = classesValue.split(/\\s+/);\n      // this boolean is used to avoid having to create a key/value map of `true` values\n      // since a classname string implies that all those classes are added\n      applyAllClasses = true;\n    } else {\n      classNames = classesValue ? Object.keys(classesValue) : EMPTY_ARRAY;\n    }\n  }\n\n  const classes = (classesValue || EMPTY_OBJ) as{[key: string]: any};\n  const styleProps = stylesValue ? Object.keys(stylesValue) : EMPTY_ARRAY;\n  const styles = stylesValue || EMPTY_OBJ;\n\n  const classesStartIndex = styleProps.length;\n  let multiStartIndex = getMultiStartIndex(context);\n\n  let dirty = false;\n  let ctxIndex = multiStartIndex;\n\n  let propIndex = 0;\n  const propLimit = styleProps.length + classNames.length;\n\n  // the main loop here will try and figure out how the shape of the provided\n  // styles differ with respect to the context. Later if the context/styles/classes\n  // are off-balance then they will be dealt in another loop after this one\n  while (ctxIndex < context.length && propIndex < propLimit) {\n    const isClassBased = propIndex >= classesStartIndex;\n    const processValue =\n        (!isClassBased && !ignoreAllStyleUpdates) || (isClassBased && !ignoreAllClassUpdates);\n\n    // when there is a cache-hit for a string-based class then we should\n    // avoid doing any work diffing any of the changes\n    if (processValue) {\n      const adjustedPropIndex = isClassBased ? propIndex - classesStartIndex : propIndex;\n      const newProp: string =\n          isClassBased ? classNames[adjustedPropIndex] : styleProps[adjustedPropIndex];\n      const newValue: string|boolean =\n          isClassBased ? (applyAllClasses ? true : classes[newProp]) : styles[newProp];\n      const playerBuilderIndex =\n          isClassBased ? classesPlayerBuilderIndex : stylesPlayerBuilderIndex;\n\n      const prop = getProp(context, ctxIndex);\n      if (prop === newProp) {\n        const value = getValue(context, ctxIndex);\n        const flag = getPointers(context, ctxIndex);\n        setPlayerBuilderIndex(context, ctxIndex, playerBuilderIndex, directiveIndex);\n\n        if (hasValueChanged(flag, value, newValue)) {\n          setValue(context, ctxIndex, newValue);\n          playerBuildersAreDirty = playerBuildersAreDirty || !!playerBuilderIndex;\n\n          const initialValue = getInitialValue(context, flag);\n\n          // SKIP IF INITIAL CHECK\n          // If the former `value` is `null` then it means that an initial value\n          // could be being rendered on screen. If that is the case then there is\n          // no point in updating the value incase it matches. In other words if the\n          // new value is the exact same as the previously rendered value (which\n          // happens to be the initial value) then do nothing.\n          if (value != null || hasValueChanged(flag, initialValue, newValue)) {\n            setDirty(context, ctxIndex, true);\n            dirty = true;\n          }\n        }\n      } else {\n        const indexOfEntry = findEntryPositionByProp(context, newProp, ctxIndex);\n        if (indexOfEntry > 0) {\n          // it was found at a later point ... just swap the values\n          const valueToCompare = getValue(context, indexOfEntry);\n          const flagToCompare = getPointers(context, indexOfEntry);\n          swapMultiContextEntries(context, ctxIndex, indexOfEntry);\n          if (hasValueChanged(flagToCompare, valueToCompare, newValue)) {\n            const initialValue = getInitialValue(context, flagToCompare);\n            setValue(context, ctxIndex, newValue);\n\n            // same if statement logic as above (look for SKIP IF INITIAL CHECK).\n            if (valueToCompare != null || hasValueChanged(flagToCompare, initialValue, newValue)) {\n              setDirty(context, ctxIndex, true);\n              playerBuildersAreDirty = playerBuildersAreDirty || !!playerBuilderIndex;\n              dirty = true;\n            }\n          }\n        } else {\n          // we only care to do this if the insertion is in the middle\n          const newFlag = prepareInitialFlag(\n              context, newProp, isClassBased, getStyleSanitizer(context, directiveIndex));\n          playerBuildersAreDirty = playerBuildersAreDirty || !!playerBuilderIndex;\n          insertNewMultiProperty(\n              context, ctxIndex, isClassBased, newProp, newFlag, newValue, directiveIndex,\n              playerBuilderIndex);\n          dirty = true;\n        }\n      }\n    }\n\n    ctxIndex += StylingIndex.Size;\n    propIndex++;\n  }\n\n  // this means that there are left-over values in the context that\n  // were not included in the provided styles/classes and in this\n  // case the  goal is to \"remove\" them from the context (by nullifying)\n  while (ctxIndex < context.length) {\n    const flag = getPointers(context, ctxIndex);\n    const isClassBased = (flag & StylingFlags.Class) === StylingFlags.Class;\n    const processValue =\n        (!isClassBased && !ignoreAllStyleUpdates) || (isClassBased && !ignoreAllClassUpdates);\n    if (processValue) {\n      const value = getValue(context, ctxIndex);\n      const doRemoveValue = valueExists(value, isClassBased);\n      if (doRemoveValue) {\n        setDirty(context, ctxIndex, true);\n        setValue(context, ctxIndex, null);\n\n        // we keep the player factory the same so that the `nulled` value can\n        // be instructed into the player because removing a style and/or a class\n        // is a valid animation player instruction.\n        const playerBuilderIndex =\n            isClassBased ? classesPlayerBuilderIndex : stylesPlayerBuilderIndex;\n        setPlayerBuilderIndex(context, ctxIndex, playerBuilderIndex, directiveIndex);\n        dirty = true;\n      }\n    }\n    ctxIndex += StylingIndex.Size;\n  }\n\n  // this means that there are left-over properties in the context that\n  // were not detected in the context during the loop above. In that\n  // case we want to add the new entries into the list\n  const sanitizer = getStyleSanitizer(context, directiveIndex);\n  while (propIndex < propLimit) {\n    const isClassBased = propIndex >= classesStartIndex;\n    const processValue =\n        (!isClassBased && !ignoreAllStyleUpdates) || (isClassBased && !ignoreAllClassUpdates);\n    if (processValue) {\n      const adjustedPropIndex = isClassBased ? propIndex - classesStartIndex : propIndex;\n      const prop = isClassBased ? classNames[adjustedPropIndex] : styleProps[adjustedPropIndex];\n      const value: string|boolean =\n          isClassBased ? (applyAllClasses ? true : classes[prop]) : styles[prop];\n      const flag = prepareInitialFlag(context, prop, isClassBased, sanitizer) | StylingFlags.Dirty;\n      const playerBuilderIndex =\n          isClassBased ? classesPlayerBuilderIndex : stylesPlayerBuilderIndex;\n      const ctxIndex = context.length;\n      context.push(flag, prop, value, 0);\n      setPlayerBuilderIndex(context, ctxIndex, playerBuilderIndex, directiveIndex);\n      dirty = true;\n    }\n    propIndex++;\n  }\n\n  if (dirty) {\n    setContextDirty(context, true);\n    setDirectiveDirty(context, directiveIndex, true);\n  }\n\n  if (playerBuildersAreDirty) {\n    setContextPlayersDirty(context, true);\n  }\n}\n\n/**\n * This method will toggle the referenced CSS class (by the provided index)\n * within the given context.\n *\n * @param context The styling context that will be updated with the\n *    newly provided class value.\n * @param offset The index of the CSS class which is being updated.\n * @param addOrRemove Whether or not to add or remove the CSS class\n */\nexport function updateClassProp(\n    context: StylingContext, offset: number, addOrRemove: boolean | BoundPlayerFactory<boolean>,\n    directiveRef?: any): void {\n  _updateSingleStylingValue(context, offset, addOrRemove, true, directiveRef);\n}\n\n/**\n * Sets and resolves a single style value on the provided `StylingContext` so\n * that they can be applied to the element once `renderStyling` is called.\n *\n * Note that prop-level styling values are considered higher priority than any styling that\n * has been applied using `updateStylingMap`, therefore, when styling values are rendered\n * then any styles/classes that have been applied using this function will be considered first\n * (then multi values second and then initial values as a backup).\n *\n * @param context The styling context that will be updated with the\n *    newly provided style value.\n * @param offset The index of the property which is being updated.\n * @param value The CSS style value that will be assigned\n * @param directiveRef an optional reference to the directive responsible\n *    for this binding change. If present then style binding will only\n *    actualize if the directive has ownership over this binding\n *    (see styling.ts#directives for more information about the algorithm).\n */\nexport function updateStyleProp(\n    context: StylingContext, offset: number,\n    input: string | boolean | null | BoundPlayerFactory<string|boolean|null>,\n    directiveRef?: any): void {\n  _updateSingleStylingValue(context, offset, input, false, directiveRef);\n}\n\nfunction _updateSingleStylingValue(\n    context: StylingContext, offset: number,\n    input: string | boolean | null | BoundPlayerFactory<string|boolean|null>, isClassBased: boolean,\n    directiveRef: any): void {\n  const directiveIndex = getDirectiveIndexFromRegistry(context, directiveRef || null);\n  const singleIndex = getSinglePropIndexValue(context, directiveIndex, offset, isClassBased);\n  const currValue = getValue(context, singleIndex);\n  const currFlag = getPointers(context, singleIndex);\n  const currDirective = getDirectiveIndexFromEntry(context, singleIndex);\n  const value: string|boolean|null = (input instanceof BoundPlayerFactory) ? input.value : input;\n\n  if (hasValueChanged(currFlag, currValue, value) &&\n      allowValueChange(currValue, value, currDirective, directiveIndex)) {\n    const isClassBased = (currFlag & StylingFlags.Class) === StylingFlags.Class;\n    const element = context[StylingIndex.ElementPosition] !as HTMLElement;\n    const playerBuilder = input instanceof BoundPlayerFactory ?\n        new ClassAndStylePlayerBuilder(\n            input as any, element, isClassBased ? BindingType.Class : BindingType.Style) :\n        null;\n    const value = (playerBuilder ? (input as BoundPlayerFactory<any>).value : input) as string |\n        boolean | null;\n    const currPlayerIndex = getPlayerBuilderIndex(context, singleIndex);\n\n    let playerBuildersAreDirty = false;\n    let playerBuilderIndex = playerBuilder ? currPlayerIndex : 0;\n    if (hasPlayerBuilderChanged(context, playerBuilder, currPlayerIndex)) {\n      const newIndex = setPlayerBuilder(context, playerBuilder, currPlayerIndex);\n      playerBuilderIndex = playerBuilder ? newIndex : 0;\n      playerBuildersAreDirty = true;\n    }\n\n    if (playerBuildersAreDirty || currDirective !== directiveIndex) {\n      setPlayerBuilderIndex(context, singleIndex, playerBuilderIndex, directiveIndex);\n    }\n\n    if (currDirective !== directiveIndex) {\n      const prop = getProp(context, singleIndex);\n      const sanitizer = getStyleSanitizer(context, directiveIndex);\n      setSanitizeFlag(context, singleIndex, (sanitizer && sanitizer(prop)) ? true : false);\n    }\n\n    // the value will always get updated (even if the dirty flag is skipped)\n    setValue(context, singleIndex, value);\n    const indexForMulti = getMultiOrSingleIndex(currFlag);\n\n    // if the value is the same in the multi-area then there's no point in re-assembling\n    const valueForMulti = getValue(context, indexForMulti);\n    if (!valueForMulti || hasValueChanged(currFlag, valueForMulti, value)) {\n      let multiDirty = false;\n      let singleDirty = true;\n\n      // only when the value is set to `null` should the multi-value get flagged\n      if (!valueExists(value, isClassBased) && valueExists(valueForMulti, isClassBased)) {\n        multiDirty = true;\n        singleDirty = false;\n      }\n\n      setDirty(context, indexForMulti, multiDirty);\n      setDirty(context, singleIndex, singleDirty);\n      setDirectiveDirty(context, directiveIndex, true);\n      setContextDirty(context, true);\n    }\n\n    if (playerBuildersAreDirty) {\n      setContextPlayersDirty(context, true);\n    }\n  }\n}\n\n\n/**\n * Renders all queued styling using a renderer onto the given element.\n *\n * This function works by rendering any styles (that have been applied\n * using `updateStylingMap`) and any classes (that have been applied using\n * `updateStyleProp`) onto the provided element using the provided renderer.\n * Just before the styles/classes are rendered a final key/value style map\n * will be assembled (if `styleStore` or `classStore` are provided).\n *\n * @param lElement the element that the styles will be rendered on\n * @param context The styling context that will be used to determine\n *      what styles will be rendered\n * @param renderer the renderer that will be used to apply the styling\n * @param classesStore if provided, the updated class values will be applied\n *    to this key/value map instead of being renderered via the renderer.\n * @param stylesStore if provided, the updated style values will be applied\n *    to this key/value map instead of being renderered via the renderer.\n * @param directiveRef an optional directive that will be used to target which\n *    styling values are rendered. If left empty, only the bindings that are\n *    registered on the template will be rendered.\n * @returns number the total amount of players that got queued for animation (if any)\n */\nexport function renderStyling(\n    context: StylingContext, renderer: Renderer3, rootOrView: RootContext | LView,\n    isFirstRender: boolean, classesStore?: BindingStore | null, stylesStore?: BindingStore | null,\n    directiveRef?: any): number {\n  let totalPlayersQueued = 0;\n  const targetDirectiveIndex = getDirectiveIndexFromRegistry(context, directiveRef || null);\n\n  if (isContextDirty(context) && isDirectiveDirty(context, targetDirectiveIndex)) {\n    const flushPlayerBuilders: any =\n        context[StylingIndex.MasterFlagPosition] & StylingFlags.PlayerBuildersDirty;\n    const native = context[StylingIndex.ElementPosition] !;\n    const multiStartIndex = getMultiStartIndex(context);\n    const onlySingleClasses = limitToSingleClasses(context);\n\n    let stillDirty = false;\n    for (let i = StylingIndex.SingleStylesStartPosition; i < context.length;\n         i += StylingIndex.Size) {\n      // there is no point in rendering styles that have not changed on screen\n      if (isDirty(context, i)) {\n        const flag = getPointers(context, i);\n        const directiveIndex = getDirectiveIndexFromEntry(context, i);\n        if (targetDirectiveIndex !== directiveIndex) {\n          stillDirty = true;\n          continue;\n        }\n\n        const prop = getProp(context, i);\n        const value = getValue(context, i);\n        const styleSanitizer =\n            (flag & StylingFlags.Sanitize) ? getStyleSanitizer(context, directiveIndex) : null;\n        const playerBuilder = getPlayerBuilder(context, i);\n        const isClassBased = flag & StylingFlags.Class ? true : false;\n        const isInSingleRegion = i < multiStartIndex;\n        const readInitialValue = !isClassBased || !onlySingleClasses;\n\n        let valueToApply: string|boolean|null = value;\n\n        // VALUE DEFER CASE 1: Use a multi value instead of a null single value\n        // this check implies that a single value was removed and we\n        // should now defer to a multi value and use that (if set).\n        if (isInSingleRegion && !valueExists(valueToApply, isClassBased)) {\n          // single values ALWAYS have a reference to a multi index\n          const multiIndex = getMultiOrSingleIndex(flag);\n          valueToApply = getValue(context, multiIndex);\n        }\n\n        // VALUE DEFER CASE 2: Use the initial value if all else fails (is falsy)\n        // the initial value will always be a string or null,\n        // therefore we can safely adopt it incase there's nothing else\n        // note that this should always be a falsy check since `false` is used\n        // for both class and style comparisons (styles can't be false and false\n        // classes are turned off and should therefore defer to their initial values)\n        // Note that we ignore class-based deferals because otherwise a class can never\n        // be removed in the case that it exists as true in the initial classes list...\n        if (!isClassBased && !valueExists(valueToApply, isClassBased) && readInitialValue) {\n          valueToApply = getInitialValue(context, flag);\n        }\n\n        // if the first render is true then we do not want to start applying falsy\n        // values to the DOM element's styling. Otherwise then we know there has\n        // been a change and even if it's falsy then it's removing something that\n        // was truthy before.\n        const doApplyValue = isFirstRender ? valueToApply : true;\n        if (doApplyValue) {\n          if (isClassBased) {\n            setClass(\n                native, prop, valueToApply ? true : false, renderer, classesStore, playerBuilder);\n          } else {\n            setStyle(\n                native, prop, valueToApply as string | null, renderer, styleSanitizer, stylesStore,\n                playerBuilder);\n          }\n        }\n\n        setDirty(context, i, false);\n      }\n    }\n\n    if (flushPlayerBuilders) {\n      const rootContext =\n          Array.isArray(rootOrView) ? getRootContext(rootOrView) : rootOrView as RootContext;\n      const playerContext = getPlayerContext(context) !;\n      const playersStartIndex = playerContext[PlayerIndex.NonBuilderPlayersStart];\n      for (let i = PlayerIndex.PlayerBuildersStartPosition; i < playersStartIndex;\n           i += PlayerIndex.PlayerAndPlayerBuildersTupleSize) {\n        const builder = playerContext[i] as ClassAndStylePlayerBuilder<any>| null;\n        const playerInsertionIndex = i + PlayerIndex.PlayerOffsetPosition;\n        const oldPlayer = playerContext[playerInsertionIndex] as Player | null;\n        if (builder) {\n          const player = builder.buildPlayer(oldPlayer, isFirstRender);\n          if (player !== undefined) {\n            if (player != null) {\n              const wasQueued = addPlayerInternal(\n                  playerContext, rootContext, native as HTMLElement, player, playerInsertionIndex);\n              wasQueued && totalPlayersQueued++;\n            }\n            if (oldPlayer) {\n              oldPlayer.destroy();\n            }\n          }\n        } else if (oldPlayer) {\n          // the player builder has been removed ... therefore we should delete the associated\n          // player\n          oldPlayer.destroy();\n        }\n      }\n      setContextPlayersDirty(context, false);\n    }\n\n    setDirectiveDirty(context, targetDirectiveIndex, false);\n    setContextDirty(context, stillDirty);\n  }\n\n  return totalPlayersQueued;\n}\n\n/**\n * This function renders a given CSS prop/value entry using the\n * provided renderer. If a `store` value is provided then\n * that will be used a render context instead of the provided\n * renderer.\n *\n * @param native the DOM Element\n * @param prop the CSS style property that will be rendered\n * @param value the CSS style value that will be rendered\n * @param renderer\n * @param store an optional key/value map that will be used as a context to render styles on\n */\nexport function setStyle(\n    native: any, prop: string, value: string | null, renderer: Renderer3,\n    sanitizer: StyleSanitizeFn | null, store?: BindingStore | null,\n    playerBuilder?: ClassAndStylePlayerBuilder<any>| null) {\n  value = sanitizer && value ? sanitizer(prop, value) : value;\n  if (store || playerBuilder) {\n    if (store) {\n      store.setValue(prop, value);\n    }\n    if (playerBuilder) {\n      playerBuilder.setValue(prop, value);\n    }\n  } else if (value) {\n    value = value.toString();  // opacity, z-index and flexbox all have number values which may not\n                               // assign as numbers\n    ngDevMode && ngDevMode.rendererSetStyle++;\n    isProceduralRenderer(renderer) ?\n        renderer.setStyle(native, prop, value, RendererStyleFlags3.DashCase) :\n        native['style'].setProperty(prop, value);\n  } else {\n    ngDevMode && ngDevMode.rendererRemoveStyle++;\n    isProceduralRenderer(renderer) ?\n        renderer.removeStyle(native, prop, RendererStyleFlags3.DashCase) :\n        native['style'].removeProperty(prop);\n  }\n}\n\n/**\n * This function renders a given CSS class value using the provided\n * renderer (by adding or removing it from the provided element).\n * If a `store` value is provided then that will be used a render\n * context instead of the provided renderer.\n *\n * @param native the DOM Element\n * @param prop the CSS style property that will be rendered\n * @param value the CSS style value that will be rendered\n * @param renderer\n * @param store an optional key/value map that will be used as a context to render styles on\n */\nfunction setClass(\n    native: any, className: string, add: boolean, renderer: Renderer3, store?: BindingStore | null,\n    playerBuilder?: ClassAndStylePlayerBuilder<any>| null) {\n  if (store || playerBuilder) {\n    if (store) {\n      store.setValue(className, add);\n    }\n    if (playerBuilder) {\n      playerBuilder.setValue(className, add);\n    }\n  } else if (add) {\n    ngDevMode && ngDevMode.rendererAddClass++;\n    isProceduralRenderer(renderer) ? renderer.addClass(native, className) :\n                                     native['classList'].add(className);\n  } else {\n    ngDevMode && ngDevMode.rendererRemoveClass++;\n    isProceduralRenderer(renderer) ? renderer.removeClass(native, className) :\n                                     native['classList'].remove(className);\n  }\n}\n\nfunction setSanitizeFlag(context: StylingContext, index: number, sanitizeYes: boolean) {\n  if (sanitizeYes) {\n    (context[index] as number) |= StylingFlags.Sanitize;\n  } else {\n    (context[index] as number) &= ~StylingFlags.Sanitize;\n  }\n}\n\nfunction setDirty(context: StylingContext, index: number, isDirtyYes: boolean) {\n  const adjustedIndex =\n      index >= StylingIndex.SingleStylesStartPosition ? (index + StylingIndex.FlagsOffset) : index;\n  if (isDirtyYes) {\n    (context[adjustedIndex] as number) |= StylingFlags.Dirty;\n  } else {\n    (context[adjustedIndex] as number) &= ~StylingFlags.Dirty;\n  }\n}\n\nfunction isDirty(context: StylingContext, index: number): boolean {\n  const adjustedIndex =\n      index >= StylingIndex.SingleStylesStartPosition ? (index + StylingIndex.FlagsOffset) : index;\n  return ((context[adjustedIndex] as number) & StylingFlags.Dirty) == StylingFlags.Dirty;\n}\n\nexport function isClassBasedValue(context: StylingContext, index: number): boolean {\n  const adjustedIndex =\n      index >= StylingIndex.SingleStylesStartPosition ? (index + StylingIndex.FlagsOffset) : index;\n  return ((context[adjustedIndex] as number) & StylingFlags.Class) == StylingFlags.Class;\n}\n\nfunction isSanitizable(context: StylingContext, index: number): boolean {\n  const adjustedIndex =\n      index >= StylingIndex.SingleStylesStartPosition ? (index + StylingIndex.FlagsOffset) : index;\n  return ((context[adjustedIndex] as number) & StylingFlags.Sanitize) == StylingFlags.Sanitize;\n}\n\nfunction pointers(configFlag: number, staticIndex: number, dynamicIndex: number) {\n  return (configFlag & StylingFlags.BitMask) | (staticIndex << StylingFlags.BitCountSize) |\n      (dynamicIndex << (StylingIndex.BitCountSize + StylingFlags.BitCountSize));\n}\n\nfunction getInitialValue(context: StylingContext, flag: number): string|boolean|null {\n  const index = getInitialIndex(flag);\n  const entryIsClassBased = flag & StylingFlags.Class;\n  const initialValues = entryIsClassBased ? context[StylingIndex.InitialClassValuesPosition] :\n                                            context[StylingIndex.InitialStyleValuesPosition];\n  return initialValues[index];\n}\n\nfunction getInitialIndex(flag: number): number {\n  return (flag >> StylingFlags.BitCountSize) & StylingIndex.BitMask;\n}\n\nfunction getMultiOrSingleIndex(flag: number): number {\n  const index =\n      (flag >> (StylingIndex.BitCountSize + StylingFlags.BitCountSize)) & StylingIndex.BitMask;\n  return index >= StylingIndex.SingleStylesStartPosition ? index : -1;\n}\n\nfunction getMultiStartIndex(context: StylingContext): number {\n  return getMultiOrSingleIndex(context[StylingIndex.MasterFlagPosition]) as number;\n}\n\nfunction setProp(context: StylingContext, index: number, prop: string) {\n  context[index + StylingIndex.PropertyOffset] = prop;\n}\n\nfunction setValue(context: StylingContext, index: number, value: string | null | boolean) {\n  context[index + StylingIndex.ValueOffset] = value;\n}\n\nfunction hasPlayerBuilderChanged(\n    context: StylingContext, builder: ClassAndStylePlayerBuilder<any>| null, index: number) {\n  const playerContext = context[StylingIndex.PlayerContext] !;\n  if (builder) {\n    if (!playerContext || index === 0) {\n      return true;\n    }\n  } else if (!playerContext) {\n    return false;\n  }\n  return playerContext[index] !== builder;\n}\n\nfunction setPlayerBuilder(\n    context: StylingContext, builder: ClassAndStylePlayerBuilder<any>| null,\n    insertionIndex: number): number {\n  let playerContext = context[StylingIndex.PlayerContext] || allocPlayerContext(context);\n  if (insertionIndex > 0) {\n    playerContext[insertionIndex] = builder;\n  } else {\n    insertionIndex = playerContext[PlayerIndex.NonBuilderPlayersStart];\n    playerContext.splice(insertionIndex, 0, builder, null);\n    playerContext[PlayerIndex.NonBuilderPlayersStart] +=\n        PlayerIndex.PlayerAndPlayerBuildersTupleSize;\n  }\n  return insertionIndex;\n}\n\nexport function directiveOwnerPointers(directiveIndex: number, playerIndex: number) {\n  return (playerIndex << DirectiveOwnerAndPlayerBuilderIndex.BitCountSize) | directiveIndex;\n}\n\nfunction setPlayerBuilderIndex(\n    context: StylingContext, index: number, playerBuilderIndex: number, directiveIndex: number) {\n  const value = directiveOwnerPointers(directiveIndex, playerBuilderIndex);\n  context[index + StylingIndex.PlayerBuilderIndexOffset] = value;\n}\n\nfunction getPlayerBuilderIndex(context: StylingContext, index: number): number {\n  const flag = context[index + StylingIndex.PlayerBuilderIndexOffset] as number;\n  const playerBuilderIndex = (flag >> DirectiveOwnerAndPlayerBuilderIndex.BitCountSize) &\n      DirectiveOwnerAndPlayerBuilderIndex.BitMask;\n  return playerBuilderIndex;\n}\n\nfunction getPlayerBuilder(context: StylingContext, index: number): ClassAndStylePlayerBuilder<any>|\n    null {\n  const playerBuilderIndex = getPlayerBuilderIndex(context, index);\n  if (playerBuilderIndex) {\n    const playerContext = context[StylingIndex.PlayerContext];\n    if (playerContext) {\n      return playerContext[playerBuilderIndex] as ClassAndStylePlayerBuilder<any>| null;\n    }\n  }\n  return null;\n}\n\nfunction setFlag(context: StylingContext, index: number, flag: number) {\n  const adjustedIndex =\n      index === StylingIndex.MasterFlagPosition ? index : (index + StylingIndex.FlagsOffset);\n  context[adjustedIndex] = flag;\n}\n\nfunction getPointers(context: StylingContext, index: number): number {\n  const adjustedIndex =\n      index === StylingIndex.MasterFlagPosition ? index : (index + StylingIndex.FlagsOffset);\n  return context[adjustedIndex] as number;\n}\n\nexport function getValue(context: StylingContext, index: number): string|boolean|null {\n  return context[index + StylingIndex.ValueOffset] as string | boolean | null;\n}\n\nexport function getProp(context: StylingContext, index: number): string {\n  return context[index + StylingIndex.PropertyOffset] as string;\n}\n\nexport function isContextDirty(context: StylingContext): boolean {\n  return isDirty(context, StylingIndex.MasterFlagPosition);\n}\n\nexport function limitToSingleClasses(context: StylingContext) {\n  return context[StylingIndex.MasterFlagPosition] & StylingFlags.OnlyProcessSingleClasses;\n}\n\nexport function setContextDirty(context: StylingContext, isDirtyYes: boolean): void {\n  setDirty(context, StylingIndex.MasterFlagPosition, isDirtyYes);\n}\n\nexport function setContextPlayersDirty(context: StylingContext, isDirtyYes: boolean): void {\n  if (isDirtyYes) {\n    (context[StylingIndex.MasterFlagPosition] as number) |= StylingFlags.PlayerBuildersDirty;\n  } else {\n    (context[StylingIndex.MasterFlagPosition] as number) &= ~StylingFlags.PlayerBuildersDirty;\n  }\n}\n\nfunction findEntryPositionByProp(\n    context: StylingContext, prop: string, startIndex?: number): number {\n  for (let i = (startIndex || 0) + StylingIndex.PropertyOffset; i < context.length;\n       i += StylingIndex.Size) {\n    const thisProp = context[i];\n    if (thisProp == prop) {\n      return i - StylingIndex.PropertyOffset;\n    }\n  }\n  return -1;\n}\n\nfunction swapMultiContextEntries(context: StylingContext, indexA: number, indexB: number) {\n  const tmpValue = getValue(context, indexA);\n  const tmpProp = getProp(context, indexA);\n  const tmpFlag = getPointers(context, indexA);\n  const tmpPlayerBuilderIndex = getPlayerBuilderIndex(context, indexA);\n\n  let flagA = tmpFlag;\n  let flagB = getPointers(context, indexB);\n\n  const singleIndexA = getMultiOrSingleIndex(flagA);\n  if (singleIndexA >= 0) {\n    const _flag = getPointers(context, singleIndexA);\n    const _initial = getInitialIndex(_flag);\n    setFlag(context, singleIndexA, pointers(_flag, _initial, indexB));\n  }\n\n  const singleIndexB = getMultiOrSingleIndex(flagB);\n  if (singleIndexB >= 0) {\n    const _flag = getPointers(context, singleIndexB);\n    const _initial = getInitialIndex(_flag);\n    setFlag(context, singleIndexB, pointers(_flag, _initial, indexA));\n  }\n\n  setValue(context, indexA, getValue(context, indexB));\n  setProp(context, indexA, getProp(context, indexB));\n  setFlag(context, indexA, getPointers(context, indexB));\n  const playerIndexA = getPlayerBuilderIndex(context, indexB);\n  const directiveIndexA = 0;\n  setPlayerBuilderIndex(context, indexA, playerIndexA, directiveIndexA);\n\n  setValue(context, indexB, tmpValue);\n  setProp(context, indexB, tmpProp);\n  setFlag(context, indexB, tmpFlag);\n  setPlayerBuilderIndex(context, indexB, tmpPlayerBuilderIndex, directiveIndexA);\n}\n\nfunction updateSinglePointerValues(context: StylingContext, indexStartPosition: number) {\n  for (let i = indexStartPosition; i < context.length; i += StylingIndex.Size) {\n    const multiFlag = getPointers(context, i);\n    const singleIndex = getMultiOrSingleIndex(multiFlag);\n    if (singleIndex > 0) {\n      const singleFlag = getPointers(context, singleIndex);\n      const initialIndexForSingle = getInitialIndex(singleFlag);\n      const flagValue = (isDirty(context, singleIndex) ? StylingFlags.Dirty : StylingFlags.None) |\n          (isClassBasedValue(context, singleIndex) ? StylingFlags.Class : StylingFlags.None) |\n          (isSanitizable(context, singleIndex) ? StylingFlags.Sanitize : StylingFlags.None);\n      const updatedFlag = pointers(flagValue, initialIndexForSingle, i);\n      setFlag(context, singleIndex, updatedFlag);\n    }\n  }\n}\n\nfunction insertNewMultiProperty(\n    context: StylingContext, index: number, classBased: boolean, name: string, flag: number,\n    value: string | boolean, directiveIndex: number, playerIndex: number): void {\n  const doShift = index < context.length;\n\n  // prop does not exist in the list, add it in\n  context.splice(\n      index, 0, flag | StylingFlags.Dirty | (classBased ? StylingFlags.Class : StylingFlags.None),\n      name, value, 0);\n  setPlayerBuilderIndex(context, index, playerIndex, directiveIndex);\n\n  if (doShift) {\n    // because the value was inserted midway into the array then we\n    // need to update all the shifted multi values' single value\n    // pointers to point to the newly shifted location\n    updateSinglePointerValues(context, index + StylingIndex.Size);\n  }\n}\n\nfunction valueExists(value: string | null | boolean, isClassBased?: boolean) {\n  if (isClassBased) {\n    return value ? true : false;\n  }\n  return value !== null;\n}\n\nfunction prepareInitialFlag(\n    context: StylingContext, prop: string, entryIsClassBased: boolean,\n    sanitizer?: StyleSanitizeFn | null) {\n  let flag = (sanitizer && sanitizer(prop)) ? StylingFlags.Sanitize : StylingFlags.None;\n\n  let initialIndex: number;\n  if (entryIsClassBased) {\n    flag |= StylingFlags.Class;\n    initialIndex =\n        getInitialStylingValuesIndexOf(context[StylingIndex.InitialClassValuesPosition], prop);\n  } else {\n    initialIndex =\n        getInitialStylingValuesIndexOf(context[StylingIndex.InitialStyleValuesPosition], prop);\n  }\n\n  initialIndex = initialIndex > 0 ? (initialIndex + InitialStylingValuesIndex.ValueOffset) : 0;\n  return pointers(flag, initialIndex, 0);\n}\n\nfunction hasValueChanged(\n    flag: number, a: string | boolean | null, b: string | boolean | null): boolean {\n  const isClassBased = flag & StylingFlags.Class;\n  const hasValues = a && b;\n  const usesSanitizer = flag & StylingFlags.Sanitize;\n  // the toString() comparison ensures that a value is checked\n  // ... otherwise (during sanitization bypassing) the === comparsion\n  // would fail since a new String() instance is created\n  if (!isClassBased && hasValues && usesSanitizer) {\n    // we know for sure we're dealing with strings at this point\n    return (a as string).toString() !== (b as string).toString();\n  }\n\n  // everything else is safe to check with a normal equality check\n  return a !== b;\n}\n\nexport class ClassAndStylePlayerBuilder<T> implements PlayerBuilder {\n  private _values: {[key: string]: string | null} = {};\n  private _dirty = false;\n  private _factory: BoundPlayerFactory<T>;\n\n  constructor(factory: PlayerFactory, private _element: HTMLElement, private _type: BindingType) {\n    this._factory = factory as any;\n  }\n\n  setValue(prop: string, value: any) {\n    if (this._values[prop] !== value) {\n      this._values[prop] = value;\n      this._dirty = true;\n    }\n  }\n\n  buildPlayer(currentPlayer: Player|null, isFirstRender: boolean): Player|undefined|null {\n    // if no values have been set here then this means the binding didn't\n    // change and therefore the binding values were not updated through\n    // `setValue` which means no new player will be provided.\n    if (this._dirty) {\n      const player = this._factory.fn(\n          this._element, this._type, this._values !, isFirstRender, currentPlayer || null);\n      this._values = {};\n      this._dirty = false;\n      return player;\n    }\n\n    return undefined;\n  }\n}\n\n/**\n * Used to provide a summary of the state of the styling context.\n *\n * This is an internal interface that is only used inside of test tooling to\n * help summarize what's going on within the styling context. None of this code\n * is designed to be exported publicly and will, therefore, be tree-shaken away\n * during runtime.\n */\nexport interface LogSummary {\n  name: string;          //\n  staticIndex: number;   //\n  dynamicIndex: number;  //\n  value: number;         //\n  flags: {\n    dirty: boolean;                     //\n    class: boolean;                     //\n    sanitize: boolean;                  //\n    playerBuildersDirty: boolean;       //\n    onlyProcessSingleClasses: boolean;  //\n    bindingAllocationLocked: boolean;   //\n  };\n}\n\n/**\n * This function is not designed to be used in production.\n * It is a utility tool for debugging and testing and it\n * will automatically be tree-shaken away during production.\n */\nexport function generateConfigSummary(source: number): LogSummary;\nexport function generateConfigSummary(source: StylingContext): LogSummary;\nexport function generateConfigSummary(source: StylingContext, index: number): LogSummary;\nexport function generateConfigSummary(source: number | StylingContext, index?: number): LogSummary {\n  let flag, name = 'config value for ';\n  if (Array.isArray(source)) {\n    if (index) {\n      name += 'index: ' + index;\n    } else {\n      name += 'master config';\n    }\n    index = index || StylingIndex.MasterFlagPosition;\n    flag = source[index] as number;\n  } else {\n    flag = source;\n    name += 'index: ' + flag;\n  }\n  const dynamicIndex = getMultiOrSingleIndex(flag);\n  const staticIndex = getInitialIndex(flag);\n  return {\n    name,\n    staticIndex,\n    dynamicIndex,\n    value: flag,\n    flags: {\n      dirty: flag & StylingFlags.Dirty ? true : false,\n      class: flag & StylingFlags.Class ? true : false,\n      sanitize: flag & StylingFlags.Sanitize ? true : false,\n      playerBuildersDirty: flag & StylingFlags.PlayerBuildersDirty ? true : false,\n      onlyProcessSingleClasses: flag & StylingFlags.OnlyProcessSingleClasses ? true : false,\n      bindingAllocationLocked: flag & StylingFlags.BindingAllocationLocked ? true : false,\n    }\n  };\n}\n\nexport function getDirectiveIndexFromEntry(context: StylingContext, index: number) {\n  const value = context[index + StylingIndex.PlayerBuilderIndexOffset] as number;\n  return value & DirectiveOwnerAndPlayerBuilderIndex.BitMask;\n}\n\nfunction getDirectiveIndexFromRegistry(context: StylingContext, directive: any) {\n  const index =\n      getDirectiveRegistryValuesIndexOf(context[StylingIndex.DirectiveRegistryPosition], directive);\n  ngDevMode &&\n      assertNotEqual(\n          index, -1,\n          `The provided directive ${directive} has not been allocated to the element\\'s style/class bindings`);\n  return index > 0 ? index / DirectiveRegistryValuesIndex.Size : 0;\n  // return index / DirectiveRegistryValuesIndex.Size;\n}\n\nfunction getDirectiveRegistryValuesIndexOf(\n    directives: DirectiveRegistryValues, directive: {}): number {\n  for (let i = 0; i < directives.length; i += DirectiveRegistryValuesIndex.Size) {\n    if (directives[i] === directive) {\n      return i;\n    }\n  }\n  return -1;\n}\n\nfunction getInitialStylingValuesIndexOf(keyValues: InitialStylingValues, key: string): number {\n  for (let i = InitialStylingValuesIndex.KeyValueStartPosition; i < keyValues.length;\n       i += InitialStylingValuesIndex.Size) {\n    if (keyValues[i] === key) return i;\n  }\n  return -1;\n}\n\nexport function compareLogSummaries(a: LogSummary, b: LogSummary) {\n  const log: string[] = [];\n  const diffs: [string, any, any][] = [];\n  diffSummaryValues(diffs, 'staticIndex', 'staticIndex', a, b);\n  diffSummaryValues(diffs, 'dynamicIndex', 'dynamicIndex', a, b);\n  Object.keys(a.flags).forEach(\n      name => { diffSummaryValues(diffs, 'flags.' + name, name, a.flags, b.flags); });\n\n  if (diffs.length) {\n    log.push('Log Summaries for:');\n    log.push('  A: ' + a.name);\n    log.push('  B: ' + b.name);\n    log.push('\\n  Differ in the following way (A !== B):');\n    diffs.forEach(result => {\n      const [name, aVal, bVal] = result;\n      log.push('    => ' + name);\n      log.push('    => ' + aVal + ' !== ' + bVal + '\\n');\n    });\n  }\n\n  return log;\n}\n\nfunction diffSummaryValues(result: any[], name: string, prop: string, a: any, b: any) {\n  const aVal = a[prop];\n  const bVal = b[prop];\n  if (aVal !== bVal) {\n    result.push([name, aVal, bVal]);\n  }\n}\n\nfunction getSinglePropIndexValue(\n    context: StylingContext, directiveIndex: number, offset: number, isClassBased: boolean) {\n  const singlePropOffsetRegistryIndex =\n      context[StylingIndex.DirectiveRegistryPosition]\n             [(directiveIndex * DirectiveRegistryValuesIndex.Size) +\n              DirectiveRegistryValuesIndex.SinglePropValuesIndexOffset] as number;\n  const offsets = context[StylingIndex.SinglePropOffsetPositions];\n  const indexForOffset = singlePropOffsetRegistryIndex +\n      SinglePropOffsetValuesIndex.ValueStartPosition +\n      (isClassBased ?\n           offsets\n               [singlePropOffsetRegistryIndex + SinglePropOffsetValuesIndex.StylesCountPosition] :\n           0) +\n      offset;\n  return offsets[indexForOffset];\n}\n\nfunction getStyleSanitizer(context: StylingContext, directiveIndex: number): StyleSanitizeFn|null {\n  const dirs = context[StylingIndex.DirectiveRegistryPosition];\n  const value = dirs\n                    [directiveIndex * DirectiveRegistryValuesIndex.Size +\n                     DirectiveRegistryValuesIndex.StyleSanitizerOffset] ||\n      dirs[DirectiveRegistryValuesIndex.StyleSanitizerOffset] || null;\n  return value as StyleSanitizeFn | null;\n}\n\nfunction isDirectiveDirty(context: StylingContext, directiveIndex: number): boolean {\n  const dirs = context[StylingIndex.DirectiveRegistryPosition];\n  return dirs\n      [directiveIndex * DirectiveRegistryValuesIndex.Size +\n       DirectiveRegistryValuesIndex.DirtyFlagOffset] as boolean;\n}\n\nfunction setDirectiveDirty(\n    context: StylingContext, directiveIndex: number, dirtyYes: boolean): void {\n  const dirs = context[StylingIndex.DirectiveRegistryPosition];\n  dirs\n      [directiveIndex * DirectiveRegistryValuesIndex.Size +\n       DirectiveRegistryValuesIndex.DirtyFlagOffset] = dirtyYes;\n}\n\nfunction allowValueChange(\n    currentValue: string | boolean | null, newValue: string | boolean | null,\n    currentDirectiveOwner: number, newDirectiveOwner: number) {\n  // the code below relies the importance of directive's being tied to their\n  // index value. The index values for each directive are derived from being\n  // registered into the styling context directive registry. The most important\n  // directive is the parent component directive (the template) and each directive\n  // that is added after is considered less important than the previous entry. This\n  // prioritization of directives enables the styling algorithm to decide if a style\n  // or class should be allowed to be updated/replaced incase an earlier directive\n  // already wrote to the exact same style-property or className value. In other words\n  // ... this decides what to do if and when there is a collision.\n  if (currentValue) {\n    if (newValue) {\n      // if a directive index is lower than it always has priority over the\n      // previous directive's value...\n      return newDirectiveOwner <= currentDirectiveOwner;\n    } else {\n      // only write a null value incase it's the same owner writing it.\n      // this avoids having a higher-priority directive write to null\n      // only to have a lesser-priority directive change right to a\n      // non-null value immediately afterwards.\n      return currentDirectiveOwner === newDirectiveOwner;\n    }\n  }\n  return true;\n}\n\n/**\n * This function is only designed to be called for `[class]` bindings when\n * `[ngClass]` (or something that uses `class` as an input) is present. Once\n * directive host bindings fully work for `[class]` and `[style]` inputs\n * then this can be deleted.\n */\nexport function getInitialClassNameValue(context: StylingContext): string {\n  let className = context[StylingIndex.CachedClassValueOrInitialClassString] as string;\n  if (className == null) {\n    className = '';\n    const initialClassValues = context[StylingIndex.InitialClassValuesPosition];\n    for (let i = InitialStylingValuesIndex.KeyValueStartPosition; i < initialClassValues.length;\n         i += InitialStylingValuesIndex.Size) {\n      const isPresent = initialClassValues[i + 1];\n      if (isPresent) {\n        className += (className.length ? ' ' : '') + initialClassValues[i];\n      }\n    }\n    context[StylingIndex.CachedClassValueOrInitialClassString] = className;\n  }\n  return className;\n}\n"]}