@angular/core 7.2.0-rc.0 → 7.2.3

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 (434) hide show
  1. package/bundles/core-testing.umd.js +193 -131
  2. package/bundles/core-testing.umd.js.map +1 -1
  3. package/bundles/core-testing.umd.min.js +11 -11
  4. package/bundles/core-testing.umd.min.js.map +1 -1
  5. package/bundles/core.umd.js +1777 -1329
  6. package/bundles/core.umd.js.map +1 -1
  7. package/bundles/core.umd.min.js +111 -125
  8. package/bundles/core.umd.min.js.map +1 -1
  9. package/core.metadata.json +1 -1
  10. package/esm2015/core.js +1 -1
  11. package/esm2015/index.js +2 -2
  12. package/esm2015/public_api.js +2 -2
  13. package/esm2015/src/application_init.js +1 -1
  14. package/esm2015/src/application_module.js +1 -1
  15. package/esm2015/src/application_ref.js +1 -1
  16. package/esm2015/src/application_tokens.js +1 -1
  17. package/esm2015/src/change_detection/change_detection.js +1 -1
  18. package/esm2015/src/change_detection/change_detection_util.js +1 -1
  19. package/esm2015/src/change_detection/change_detector_ref.js +1 -1
  20. package/esm2015/src/change_detection/constants.js +3 -3
  21. package/esm2015/src/change_detection/differs/default_iterable_differ.js +1 -1
  22. package/esm2015/src/change_detection/differs/default_keyvalue_differ.js +1 -1
  23. package/esm2015/src/change_detection/differs/iterable_differs.js +1 -1
  24. package/esm2015/src/change_detection/differs/keyvalue_differs.js +1 -1
  25. package/esm2015/src/change_detection/pipe_transform.js +1 -1
  26. package/esm2015/src/change_detection.js +1 -1
  27. package/esm2015/src/codegen_private_exports.js +1 -1
  28. package/esm2015/src/console.js +1 -1
  29. package/esm2015/src/core.js +2 -2
  30. package/esm2015/src/core_private_export.js +1 -1
  31. package/esm2015/src/core_render3_private_export.js +2 -2
  32. package/esm2015/src/debug/debug_node.js +6 -6
  33. package/esm2015/src/di/defs.js +1 -1
  34. package/esm2015/src/di/forward_ref.js +1 -1
  35. package/esm2015/src/di/injectable.js +1 -1
  36. package/esm2015/src/di/injection_token.js +2 -2
  37. package/esm2015/src/di/injector.js +1 -1
  38. package/esm2015/src/di/injector_compatibility.js +1 -1
  39. package/esm2015/src/di/metadata.js +1 -1
  40. package/esm2015/src/di/provider.js +1 -1
  41. package/esm2015/src/di/r3_injector.js +1 -1
  42. package/esm2015/src/di/reflective_errors.js +1 -1
  43. package/esm2015/src/di/reflective_injector.js +1 -1
  44. package/esm2015/src/di/reflective_key.js +1 -1
  45. package/esm2015/src/di/reflective_provider.js +1 -1
  46. package/esm2015/src/di/scope.js +1 -1
  47. package/esm2015/src/di/util.js +1 -1
  48. package/esm2015/src/di.js +1 -1
  49. package/esm2015/src/error_handler.js +1 -1
  50. package/esm2015/src/errors.js +1 -1
  51. package/esm2015/src/event_emitter.js +1 -1
  52. package/esm2015/src/i18n/tokens.js +1 -1
  53. package/esm2015/src/is_dev_mode.js +1 -1
  54. package/esm2015/src/ivy_switch.js +1 -1
  55. package/esm2015/src/linker/compiler.js +1 -1
  56. package/esm2015/src/linker/component_factory.js +1 -1
  57. package/esm2015/src/linker/component_factory_resolver.js +1 -1
  58. package/esm2015/src/linker/element_ref.js +1 -1
  59. package/esm2015/src/linker/ng_module_factory.js +1 -1
  60. package/esm2015/src/linker/ng_module_factory_loader.js +1 -1
  61. package/esm2015/src/linker/query_list.js +1 -1
  62. package/esm2015/src/linker/system_js_ng_module_factory_loader.js +1 -1
  63. package/esm2015/src/linker/template_ref.js +6 -4
  64. package/esm2015/src/linker/view_container_ref.js +1 -1
  65. package/esm2015/src/linker/view_ref.js +1 -1
  66. package/esm2015/src/linker.js +1 -1
  67. package/esm2015/src/metadata/di.js +1 -1
  68. package/esm2015/src/metadata/directives.js +1 -1
  69. package/esm2015/src/metadata/lifecycle_hooks.js +1 -1
  70. package/esm2015/src/metadata/ng_module.js +1 -1
  71. package/esm2015/src/metadata/resource_loading.js +1 -1
  72. package/esm2015/src/metadata/view.js +1 -1
  73. package/esm2015/src/metadata.js +1 -1
  74. package/esm2015/src/platform_core_providers.js +1 -1
  75. package/esm2015/src/profile/profile.js +1 -1
  76. package/esm2015/src/profile/wtf_impl.js +1 -1
  77. package/esm2015/src/r3_symbols.js +1 -1
  78. package/esm2015/src/reflection/platform_reflection_capabilities.js +1 -1
  79. package/esm2015/src/reflection/reflection.js +1 -1
  80. package/esm2015/src/reflection/reflection_capabilities.js +1 -1
  81. package/esm2015/src/reflection/reflector.js +1 -1
  82. package/esm2015/src/reflection/types.js +1 -1
  83. package/esm2015/src/render/api.js +1 -1
  84. package/esm2015/src/render.js +1 -1
  85. package/esm2015/src/render3/assert.js +1 -1
  86. package/esm2015/src/render3/bindings.js +3 -3
  87. package/esm2015/src/render3/component.js +8 -6
  88. package/esm2015/src/render3/component_ref.js +5 -5
  89. package/esm2015/src/render3/context_discovery.js +2 -2
  90. package/esm2015/src/render3/definition.js +3 -10
  91. package/esm2015/src/render3/di.js +107 -93
  92. package/esm2015/src/render3/di_setup.js +1 -1
  93. package/esm2015/src/render3/discovery_utils.js +5 -5
  94. package/esm2015/src/render3/empty.js +28 -0
  95. package/esm2015/src/render3/errors.js +1 -1
  96. package/esm2015/src/render3/features/inherit_definition_feature.js +3 -3
  97. package/esm2015/src/render3/features/ng_onchanges_feature.js +1 -1
  98. package/esm2015/src/render3/features/providers_feature.js +1 -1
  99. package/esm2015/src/render3/fields.js +1 -1
  100. package/esm2015/src/render3/global_utils.js +1 -1
  101. package/esm2015/src/render3/global_utils_api.js +1 -1
  102. package/esm2015/src/render3/hooks.js +14 -12
  103. package/esm2015/src/render3/i18n.js +3 -3
  104. package/esm2015/src/render3/index.js +2 -2
  105. package/esm2015/src/render3/instructions.js +319 -370
  106. package/esm2015/src/render3/interfaces/container.js +10 -1
  107. package/esm2015/src/render3/interfaces/context.js +1 -1
  108. package/esm2015/src/render3/interfaces/definition.js +1 -6
  109. package/esm2015/src/render3/interfaces/i18n.js +1 -1
  110. package/esm2015/src/render3/interfaces/injector.js +1 -2
  111. package/esm2015/src/render3/interfaces/node.js +37 -2
  112. package/esm2015/src/render3/interfaces/player.js +1 -1
  113. package/esm2015/src/render3/interfaces/projection.js +1 -1
  114. package/esm2015/src/render3/interfaces/query.js +1 -1
  115. package/esm2015/src/render3/interfaces/renderer.js +1 -1
  116. package/esm2015/src/render3/interfaces/sanitization.js +1 -1
  117. package/esm2015/src/render3/interfaces/styling.js +304 -113
  118. package/esm2015/src/render3/interfaces/view.js +15 -7
  119. package/esm2015/src/render3/jit/compiler_facade.js +1 -1
  120. package/esm2015/src/render3/jit/compiler_facade_interface.js +3 -1
  121. package/esm2015/src/render3/jit/directive.js +6 -7
  122. package/esm2015/src/render3/jit/environment.js +3 -1
  123. package/esm2015/src/render3/jit/injectable.js +1 -1
  124. package/esm2015/src/render3/jit/module.js +11 -9
  125. package/esm2015/src/render3/jit/pipe.js +1 -1
  126. package/esm2015/src/render3/jit/util.js +1 -1
  127. package/esm2015/src/render3/metadata.js +1 -1
  128. package/esm2015/src/render3/ng_dev_mode.js +1 -1
  129. package/esm2015/src/render3/ng_module_ref.js +1 -1
  130. package/esm2015/src/render3/node_assert.js +1 -1
  131. package/esm2015/src/render3/node_manipulation.js +5 -22
  132. package/esm2015/src/render3/node_selector_matcher.js +3 -3
  133. package/esm2015/src/render3/pipe.js +2 -2
  134. package/esm2015/src/render3/players.js +1 -1
  135. package/esm2015/src/render3/pure_function.js +3 -3
  136. package/esm2015/src/render3/query.js +3 -3
  137. package/esm2015/src/render3/state.js +14 -20
  138. package/esm2015/src/render3/styling/class_and_style_bindings.js +893 -213
  139. package/esm2015/src/render3/styling/core_player_handler.js +1 -1
  140. package/esm2015/src/render3/styling/player_factory.js +1 -1
  141. package/esm2015/src/render3/styling/util.js +37 -14
  142. package/esm2015/src/render3/tokens.js +1 -1
  143. package/esm2015/src/render3/util.js +21 -5
  144. package/esm2015/src/render3/view_engine_compatibility.js +5 -6
  145. package/esm2015/src/render3/view_engine_compatibility_prebound.js +1 -1
  146. package/esm2015/src/render3/view_ref.js +6 -16
  147. package/esm2015/src/sanitization/bypass.js +1 -1
  148. package/esm2015/src/sanitization/html_sanitizer.js +2 -2
  149. package/esm2015/src/sanitization/inert_body.js +4 -4
  150. package/esm2015/src/sanitization/sanitization.js +1 -1
  151. package/esm2015/src/sanitization/security.js +1 -1
  152. package/esm2015/src/sanitization/style_sanitizer.js +1 -1
  153. package/esm2015/src/sanitization/url_sanitizer.js +1 -1
  154. package/esm2015/src/testability/testability.js +1 -1
  155. package/esm2015/src/type.js +1 -1
  156. package/esm2015/src/util/decorators.js +1 -1
  157. package/esm2015/src/util/lang.js +1 -1
  158. package/esm2015/src/util/ng_reflect.js +1 -1
  159. package/esm2015/src/util/noop.js +1 -1
  160. package/esm2015/src/util/property.js +1 -1
  161. package/esm2015/src/util.js +1 -1
  162. package/esm2015/src/version.js +2 -2
  163. package/esm2015/src/view/element.js +1 -1
  164. package/esm2015/src/view/entrypoint.js +1 -1
  165. package/esm2015/src/view/errors.js +1 -1
  166. package/esm2015/src/view/index.js +1 -1
  167. package/esm2015/src/view/ng_content.js +1 -1
  168. package/esm2015/src/view/ng_module.js +1 -1
  169. package/esm2015/src/view/provider.js +1 -1
  170. package/esm2015/src/view/pure_expression.js +1 -1
  171. package/esm2015/src/view/query.js +1 -1
  172. package/esm2015/src/view/refs.js +1 -1
  173. package/esm2015/src/view/services.js +1 -1
  174. package/esm2015/src/view/text.js +1 -1
  175. package/esm2015/src/view/types.js +1 -1
  176. package/esm2015/src/view/util.js +1 -1
  177. package/esm2015/src/view/view.js +1 -1
  178. package/esm2015/src/view/view_attach.js +1 -1
  179. package/esm2015/src/zone/ng_zone.js +1 -1
  180. package/esm2015/src/zone.js +1 -1
  181. package/esm2015/testing/index.js +1 -1
  182. package/esm2015/testing/public_api.js +1 -1
  183. package/esm2015/testing/src/async.js +1 -1
  184. package/esm2015/testing/src/async_fallback.js +1 -1
  185. package/esm2015/testing/src/async_test_completer.js +1 -1
  186. package/esm2015/testing/src/before_each.js +1 -1
  187. package/esm2015/testing/src/component_fixture.js +1 -1
  188. package/esm2015/testing/src/fake_async.js +1 -1
  189. package/esm2015/testing/src/fake_async_fallback.js +1 -1
  190. package/esm2015/testing/src/lang_utils.js +1 -1
  191. package/esm2015/testing/src/logger.js +1 -1
  192. package/esm2015/testing/src/metadata_override.js +1 -1
  193. package/esm2015/testing/src/metadata_overrider.js +1 -1
  194. package/esm2015/testing/src/ng_zone_mock.js +1 -1
  195. package/esm2015/testing/src/private_export_testing.js +1 -1
  196. package/esm2015/testing/src/r3_test_bed.js +234 -152
  197. package/esm2015/testing/src/resolvers.js +12 -5
  198. package/esm2015/testing/src/test_bed.js +1 -1
  199. package/esm2015/testing/src/test_bed_common.js +1 -1
  200. package/esm2015/testing/src/test_compiler.js +1 -1
  201. package/esm2015/testing/src/testing.js +1 -1
  202. package/esm2015/testing/src/testing_internal.js +2 -2
  203. package/esm2015/testing/testing.js +1 -1
  204. package/esm5/core.js +1 -1
  205. package/esm5/index.js +1 -1
  206. package/esm5/public_api.js +1 -1
  207. package/esm5/src/application_init.js +1 -1
  208. package/esm5/src/application_module.js +1 -1
  209. package/esm5/src/application_ref.js +1 -1
  210. package/esm5/src/application_tokens.js +1 -1
  211. package/esm5/src/change_detection/change_detection.js +1 -1
  212. package/esm5/src/change_detection/change_detection_util.js +1 -1
  213. package/esm5/src/change_detection/change_detector_ref.js +1 -1
  214. package/esm5/src/change_detection/constants.js +3 -3
  215. package/esm5/src/change_detection/differs/default_iterable_differ.js +1 -1
  216. package/esm5/src/change_detection/differs/default_keyvalue_differ.js +1 -1
  217. package/esm5/src/change_detection/differs/iterable_differs.js +1 -1
  218. package/esm5/src/change_detection/differs/keyvalue_differs.js +1 -1
  219. package/esm5/src/change_detection/pipe_transform.js +1 -1
  220. package/esm5/src/change_detection.js +1 -1
  221. package/esm5/src/codegen_private_exports.js +1 -1
  222. package/esm5/src/console.js +1 -1
  223. package/esm5/src/core.js +1 -1
  224. package/esm5/src/core_private_export.js +1 -1
  225. package/esm5/src/core_render3_private_export.js +2 -2
  226. package/esm5/src/debug/debug_node.js +6 -6
  227. package/esm5/src/di/defs.js +1 -1
  228. package/esm5/src/di/forward_ref.js +1 -1
  229. package/esm5/src/di/injectable.js +1 -1
  230. package/esm5/src/di/injection_token.js +2 -2
  231. package/esm5/src/di/injector.js +1 -1
  232. package/esm5/src/di/injector_compatibility.js +1 -1
  233. package/esm5/src/di/metadata.js +1 -1
  234. package/esm5/src/di/provider.js +1 -1
  235. package/esm5/src/di/r3_injector.js +1 -1
  236. package/esm5/src/di/reflective_errors.js +1 -1
  237. package/esm5/src/di/reflective_injector.js +1 -1
  238. package/esm5/src/di/reflective_key.js +1 -1
  239. package/esm5/src/di/reflective_provider.js +1 -1
  240. package/esm5/src/di/scope.js +1 -1
  241. package/esm5/src/di/util.js +1 -1
  242. package/esm5/src/di.js +1 -1
  243. package/esm5/src/error_handler.js +1 -1
  244. package/esm5/src/errors.js +1 -1
  245. package/esm5/src/event_emitter.js +1 -1
  246. package/esm5/src/i18n/tokens.js +1 -1
  247. package/esm5/src/is_dev_mode.js +1 -1
  248. package/esm5/src/ivy_switch.js +1 -1
  249. package/esm5/src/linker/compiler.js +1 -1
  250. package/esm5/src/linker/component_factory.js +1 -1
  251. package/esm5/src/linker/component_factory_resolver.js +1 -1
  252. package/esm5/src/linker/element_ref.js +1 -1
  253. package/esm5/src/linker/ng_module_factory.js +1 -1
  254. package/esm5/src/linker/ng_module_factory_loader.js +1 -1
  255. package/esm5/src/linker/query_list.js +1 -1
  256. package/esm5/src/linker/system_js_ng_module_factory_loader.js +1 -1
  257. package/esm5/src/linker/template_ref.js +1 -1
  258. package/esm5/src/linker/view_container_ref.js +1 -1
  259. package/esm5/src/linker/view_ref.js +1 -1
  260. package/esm5/src/linker.js +1 -1
  261. package/esm5/src/metadata/di.js +1 -1
  262. package/esm5/src/metadata/directives.js +1 -1
  263. package/esm5/src/metadata/lifecycle_hooks.js +1 -1
  264. package/esm5/src/metadata/ng_module.js +1 -1
  265. package/esm5/src/metadata/resource_loading.js +1 -1
  266. package/esm5/src/metadata/view.js +1 -1
  267. package/esm5/src/metadata.js +1 -1
  268. package/esm5/src/platform_core_providers.js +1 -1
  269. package/esm5/src/profile/profile.js +1 -1
  270. package/esm5/src/profile/wtf_impl.js +1 -1
  271. package/esm5/src/r3_symbols.js +1 -1
  272. package/esm5/src/reflection/platform_reflection_capabilities.js +1 -1
  273. package/esm5/src/reflection/reflection.js +1 -1
  274. package/esm5/src/reflection/reflection_capabilities.js +1 -1
  275. package/esm5/src/reflection/reflector.js +1 -1
  276. package/esm5/src/reflection/types.js +1 -1
  277. package/esm5/src/render/api.js +1 -1
  278. package/esm5/src/render.js +1 -1
  279. package/esm5/src/render3/assert.js +1 -1
  280. package/esm5/src/render3/bindings.js +3 -3
  281. package/esm5/src/render3/component.js +8 -6
  282. package/esm5/src/render3/component_ref.js +5 -5
  283. package/esm5/src/render3/context_discovery.js +2 -2
  284. package/esm5/src/render3/definition.js +3 -8
  285. package/esm5/src/render3/di.js +94 -84
  286. package/esm5/src/render3/di_setup.js +1 -1
  287. package/esm5/src/render3/discovery_utils.js +5 -5
  288. package/esm5/src/render3/empty.js +22 -0
  289. package/esm5/src/render3/errors.js +1 -1
  290. package/esm5/src/render3/features/inherit_definition_feature.js +3 -3
  291. package/esm5/src/render3/features/ng_onchanges_feature.js +1 -1
  292. package/esm5/src/render3/features/providers_feature.js +1 -1
  293. package/esm5/src/render3/fields.js +1 -1
  294. package/esm5/src/render3/global_utils.js +1 -1
  295. package/esm5/src/render3/global_utils_api.js +1 -1
  296. package/esm5/src/render3/hooks.js +11 -9
  297. package/esm5/src/render3/i18n.js +3 -3
  298. package/esm5/src/render3/index.js +2 -2
  299. package/esm5/src/render3/instructions.js +282 -282
  300. package/esm5/src/render3/interfaces/container.js +9 -1
  301. package/esm5/src/render3/interfaces/context.js +1 -1
  302. package/esm5/src/render3/interfaces/definition.js +1 -1
  303. package/esm5/src/render3/interfaces/i18n.js +1 -1
  304. package/esm5/src/render3/interfaces/injector.js +1 -1
  305. package/esm5/src/render3/interfaces/node.js +1 -1
  306. package/esm5/src/render3/interfaces/player.js +1 -1
  307. package/esm5/src/render3/interfaces/projection.js +1 -1
  308. package/esm5/src/render3/interfaces/query.js +1 -1
  309. package/esm5/src/render3/interfaces/renderer.js +1 -1
  310. package/esm5/src/render3/interfaces/sanitization.js +1 -1
  311. package/esm5/src/render3/interfaces/styling.js +1 -1
  312. package/esm5/src/render3/interfaces/view.js +1 -1
  313. package/esm5/src/render3/jit/compiler_facade.js +1 -1
  314. package/esm5/src/render3/jit/compiler_facade_interface.js +1 -1
  315. package/esm5/src/render3/jit/directive.js +6 -6
  316. package/esm5/src/render3/jit/environment.js +3 -1
  317. package/esm5/src/render3/jit/injectable.js +1 -1
  318. package/esm5/src/render3/jit/module.js +10 -8
  319. package/esm5/src/render3/jit/pipe.js +1 -1
  320. package/esm5/src/render3/jit/util.js +1 -1
  321. package/esm5/src/render3/metadata.js +1 -1
  322. package/esm5/src/render3/ng_dev_mode.js +1 -1
  323. package/esm5/src/render3/ng_module_ref.js +1 -1
  324. package/esm5/src/render3/node_assert.js +1 -1
  325. package/esm5/src/render3/node_manipulation.js +5 -21
  326. package/esm5/src/render3/node_selector_matcher.js +3 -3
  327. package/esm5/src/render3/pipe.js +2 -2
  328. package/esm5/src/render3/players.js +1 -1
  329. package/esm5/src/render3/pure_function.js +3 -3
  330. package/esm5/src/render3/query.js +3 -3
  331. package/esm5/src/render3/state.js +14 -19
  332. package/esm5/src/render3/styling/class_and_style_bindings.js +681 -210
  333. package/esm5/src/render3/styling/core_player_handler.js +1 -1
  334. package/esm5/src/render3/styling/player_factory.js +1 -1
  335. package/esm5/src/render3/styling/util.js +26 -13
  336. package/esm5/src/render3/tokens.js +1 -1
  337. package/esm5/src/render3/util.js +20 -5
  338. package/esm5/src/render3/view_engine_compatibility.js +5 -6
  339. package/esm5/src/render3/view_engine_compatibility_prebound.js +1 -1
  340. package/esm5/src/render3/view_ref.js +6 -15
  341. package/esm5/src/sanitization/bypass.js +1 -1
  342. package/esm5/src/sanitization/html_sanitizer.js +2 -2
  343. package/esm5/src/sanitization/inert_body.js +4 -4
  344. package/esm5/src/sanitization/sanitization.js +1 -1
  345. package/esm5/src/sanitization/security.js +1 -1
  346. package/esm5/src/sanitization/style_sanitizer.js +1 -1
  347. package/esm5/src/sanitization/url_sanitizer.js +1 -1
  348. package/esm5/src/testability/testability.js +1 -1
  349. package/esm5/src/type.js +1 -1
  350. package/esm5/src/util/decorators.js +1 -1
  351. package/esm5/src/util/lang.js +1 -1
  352. package/esm5/src/util/ng_reflect.js +1 -1
  353. package/esm5/src/util/noop.js +1 -1
  354. package/esm5/src/util/property.js +1 -1
  355. package/esm5/src/util.js +1 -1
  356. package/esm5/src/version.js +2 -2
  357. package/esm5/src/view/element.js +1 -1
  358. package/esm5/src/view/entrypoint.js +1 -1
  359. package/esm5/src/view/errors.js +1 -1
  360. package/esm5/src/view/index.js +1 -1
  361. package/esm5/src/view/ng_content.js +1 -1
  362. package/esm5/src/view/ng_module.js +1 -1
  363. package/esm5/src/view/provider.js +1 -1
  364. package/esm5/src/view/pure_expression.js +1 -1
  365. package/esm5/src/view/query.js +1 -1
  366. package/esm5/src/view/refs.js +1 -1
  367. package/esm5/src/view/services.js +1 -1
  368. package/esm5/src/view/text.js +1 -1
  369. package/esm5/src/view/types.js +1 -1
  370. package/esm5/src/view/util.js +1 -1
  371. package/esm5/src/view/view.js +1 -1
  372. package/esm5/src/view/view_attach.js +1 -1
  373. package/esm5/src/zone/ng_zone.js +1 -1
  374. package/esm5/src/zone.js +1 -1
  375. package/esm5/testing/index.js +1 -1
  376. package/esm5/testing/public_api.js +1 -1
  377. package/esm5/testing/src/async.js +1 -1
  378. package/esm5/testing/src/async_fallback.js +1 -1
  379. package/esm5/testing/src/async_test_completer.js +1 -1
  380. package/esm5/testing/src/before_each.js +1 -1
  381. package/esm5/testing/src/component_fixture.js +1 -1
  382. package/esm5/testing/src/fake_async.js +1 -1
  383. package/esm5/testing/src/fake_async_fallback.js +1 -1
  384. package/esm5/testing/src/lang_utils.js +1 -1
  385. package/esm5/testing/src/logger.js +1 -1
  386. package/esm5/testing/src/metadata_override.js +1 -1
  387. package/esm5/testing/src/metadata_overrider.js +1 -1
  388. package/esm5/testing/src/ng_zone_mock.js +1 -1
  389. package/esm5/testing/src/private_export_testing.js +1 -1
  390. package/esm5/testing/src/r3_test_bed.js +174 -127
  391. package/esm5/testing/src/resolvers.js +11 -6
  392. package/esm5/testing/src/test_bed.js +1 -1
  393. package/esm5/testing/src/test_bed_common.js +1 -1
  394. package/esm5/testing/src/test_compiler.js +1 -1
  395. package/esm5/testing/src/testing.js +1 -1
  396. package/esm5/testing/src/testing_internal.js +2 -2
  397. package/esm5/testing/testing.js +1 -1
  398. package/fesm2015/core.js +2306 -1733
  399. package/fesm2015/core.js.map +1 -1
  400. package/fesm2015/testing.js +223 -150
  401. package/fesm2015/testing.js.map +1 -1
  402. package/fesm5/core.js +1781 -1335
  403. package/fesm5/core.js.map +1 -1
  404. package/fesm5/testing.js +181 -130
  405. package/fesm5/testing.js.map +1 -1
  406. package/package.json +1 -1
  407. package/src/change_detection/constants.d.ts +2 -2
  408. package/src/core_render3_private_export.d.ts +1 -1
  409. package/src/di/injection_token.d.ts +1 -1
  410. package/src/event_emitter.d.ts +2 -2
  411. package/src/linker/template_ref.d.ts +5 -3
  412. package/src/metadata/di.d.ts +1 -3
  413. package/src/metadata/directives.d.ts +3 -3
  414. package/src/render3/definition.d.ts +2 -4
  415. package/src/render3/di.d.ts +4 -3
  416. package/src/render3/empty.d.ts +16 -0
  417. package/src/render3/hooks.d.ts +3 -3
  418. package/src/render3/index.d.ts +1 -1
  419. package/src/render3/instructions.d.ts +117 -72
  420. package/src/render3/interfaces/container.d.ts +1 -0
  421. package/src/render3/interfaces/definition.d.ts +0 -3
  422. package/src/render3/interfaces/injector.d.ts +0 -1
  423. package/src/render3/interfaces/node.d.ts +37 -2
  424. package/src/render3/interfaces/styling.d.ts +392 -117
  425. package/src/render3/interfaces/view.d.ts +14 -6
  426. package/src/render3/jit/compiler_facade_interface.d.ts +2 -0
  427. package/src/render3/node_manipulation.d.ts +0 -7
  428. package/src/render3/state.d.ts +3 -4
  429. package/src/render3/styling/class_and_style_bindings.d.ts +114 -43
  430. package/src/render3/styling/util.d.ts +5 -2
  431. package/src/render3/util.d.ts +7 -0
  432. package/testing/src/r3_test_bed.d.ts +15 -0
  433. package/testing/testing.metadata.json +1 -1
  434. package/testing.d.ts +2 -3
@@ -2,170 +2,477 @@
2
2
  * @fileoverview added by tsickle
3
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);
44
- // we use two maps since a class name might collide with a CSS style prop
31
+ const context = createEmptyStylingContext();
45
32
  /** @type {?} */
46
- const stylesLookup = {};
33
+ const initialClasses = context[3 /* InitialClassValuesPosition */] =
34
+ [null];
47
35
  /** @type {?} */
48
- 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.
49
40
  /** @type {?} */
50
- let totalStyleDeclarations = 0;
51
- if (initialStyleDeclarations) {
41
+ let mode = -1;
42
+ for (let i = 0; i < attrs.length; i++) {
43
+ /** @type {?} */
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;
52
84
  /** @type {?} */
53
- let hasPassedDeclarations = false;
54
- for (let i = 0; i < initialStyleDeclarations.length; i++) {
85
+ let mode = -1;
86
+ for (let i = 0; i < attrs.length; i++) {
55
87
  /** @type {?} */
56
- const v = (/** @type {?} */ (initialStyleDeclarations[i]));
57
- // this flag value marks where the declarations end the initial values begin
58
- if (v === 1 /* VALUES_MODE */) {
59
- hasPassedDeclarations = true;
88
+ const attr = attrs[i];
89
+ if (typeof attr == 'number') {
90
+ mode = attr;
60
91
  }
61
- else {
62
- /** @type {?} */
63
- const prop = (/** @type {?} */ (v));
64
- if (hasPassedDeclarations) {
65
- /** @type {?} */
66
- const value = (/** @type {?} */ (initialStyleDeclarations[++i]));
67
- initialStylingValues.push(value);
68
- stylesLookup[prop] = initialStylingValues.length - 1;
69
- }
70
- else {
71
- totalStyleDeclarations++;
72
- stylesLookup[prop] = 0;
73
- }
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]);
74
99
  }
75
100
  }
76
101
  }
77
- // make where the class offsets begin
78
- context[4 /* ClassOffsetPosition */] = totalStyleDeclarations;
79
- /** @type {?} */
80
- const initialStaticClasses = onlyProcessSingleClasses ? [] : null;
81
- 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;) {
82
118
  /** @type {?} */
83
- let hasPassedDeclarations = false;
84
- for (let i = 0; i < initialClassDeclarations.length; i++) {
119
+ const key = initialStyling[i];
120
+ if (key === prop) {
85
121
  /** @type {?} */
86
- const v = (/** @type {?} */ (initialClassDeclarations[i]));
87
- // this flag value marks where the declarations end the initial values begin
88
- if (v === 1 /* VALUES_MODE */) {
89
- 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);
90
167
  }
91
168
  else {
92
- /** @type {?} */
93
- const className = (/** @type {?} */ (v));
94
- if (hasPassedDeclarations) {
95
- /** @type {?} */
96
- const value = (/** @type {?} */ (initialClassDeclarations[++i]));
97
- initialStylingValues.push(value);
98
- classesLookup[className] = initialStylingValues.length - 1;
99
- initialStaticClasses && initialStaticClasses.push(className);
100
- }
101
- else {
102
- classesLookup[className] = 0;
103
- }
169
+ setStyle(element, (/** @type {?} */ (initialStylingValues[i + 0 /* PropOffset */])), (/** @type {?} */ (value)), renderer, null);
104
170
  }
105
171
  }
106
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.
107
212
  /** @type {?} */
108
- const styleProps = Object.keys(stylesLookup);
213
+ const singlePropOffsetValues = context[4 /* SinglePropOffsetPositions */];
109
214
  /** @type {?} */
110
- const classNames = Object.keys(classesLookup);
215
+ const totalCurrentClassBindings = singlePropOffsetValues[1 /* ClassesCountPosition */];
111
216
  /** @type {?} */
112
- const classNamesIndexStart = styleProps.length;
217
+ const totalCurrentStyleBindings = singlePropOffsetValues[0 /* StylesCountPosition */];
113
218
  /** @type {?} */
114
- const totalProps = styleProps.length + classNames.length;
115
- // *2 because we are filling for both single and multi style spaces
219
+ const classesOffset = totalCurrentClassBindings * 4 /* Size */;
116
220
  /** @type {?} */
117
- const maxLength = totalProps * 4 /* Size */ * 2 + 8 /* SingleStylesStartPosition */;
118
- // we need to fill the array from the start so that we can access
119
- // both the multi and the single array positions in the same loop block
120
- for (let i = 8 /* SingleStylesStartPosition */; i < maxLength; i++) {
221
+ const stylesOffset = totalCurrentStyleBindings * 4 /* Size */;
222
+ /** @type {?} */
223
+ const singleStylesStartIndex = 9 /* SingleStylesStartPosition */;
224
+ /** @type {?} */
225
+ let singleClassesStartIndex = singleStylesStartIndex + stylesOffset;
226
+ /** @type {?} */
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);
121
343
  context.push(null);
344
+ multiStylesStartIndex++;
345
+ multiClassesStartIndex++;
122
346
  }
123
347
  /** @type {?} */
124
- const singleStart = 8 /* SingleStylesStartPosition */;
348
+ const initialClasses = context[3 /* InitialClassValuesPosition */];
125
349
  /** @type {?} */
126
- const multiStart = totalProps * 4 /* Size */ + 8 /* SingleStylesStartPosition */;
127
- // fill single and multi-level styles
128
- 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++) {
129
355
  /** @type {?} */
130
- const isClassBased = i >= classNamesIndexStart;
356
+ const entryIsClassBased = i >= filteredStyleBindingNames.length;
131
357
  /** @type {?} */
132
- const prop = isClassBased ? classNames[i - classNamesIndexStart] : styleProps[i];
358
+ const adjustedIndex = entryIsClassBased ? (i - filteredStyleBindingNames.length) : i;
133
359
  /** @type {?} */
134
- const indexForInitial = isClassBased ? classesLookup[prop] : stylesLookup[prop];
360
+ const propName = entryIsClassBased ? filteredClassBindingNames[adjustedIndex] :
361
+ filteredStyleBindingNames[adjustedIndex];
135
362
  /** @type {?} */
136
- const initialValue = initialStylingValues[indexForInitial];
363
+ let multiIndex;
137
364
  /** @type {?} */
138
- 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.
139
381
  /** @type {?} */
140
- const indexForSingle = i * 4 /* Size */ + singleStart;
382
+ let initialValuesToLookup = entryIsClassBased ? initialClasses : initialStyles;
141
383
  /** @type {?} */
142
- const initialFlag = prepareInitialFlag(prop, isClassBased, styleSanitizer || null);
143
- setFlag(context, indexForSingle, pointers(initialFlag, indexForInitial, indexForMulti));
144
- setProp(context, indexForSingle, prop);
145
- setValue(context, indexForSingle, null);
146
- 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
+ }
147
392
  /** @type {?} */
148
- const flagForMulti = initialFlag | (initialValue !== null ? 1 /* Dirty */ : 0 /* None */);
149
- setFlag(context, indexForMulti, pointers(flagForMulti, indexForInitial, indexForSingle));
150
- setProp(context, indexForMulti, prop);
151
- setValue(context, indexForMulti, null);
152
- 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);
153
402
  }
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;
154
410
  // there is no initial value flag for the master index since it doesn't
155
411
  // reference an initial style value
156
412
  /** @type {?} */
157
- const masterFlag = pointers(0, 0, multiStart) |
413
+ const masterFlag = pointers(0, 0, multiStylesStartIndex) |
158
414
  (onlyProcessSingleClasses ? 16 /* OnlyProcessSingleClasses */ : 0);
159
- setFlag(context, 3 /* MasterFlagPosition */, masterFlag);
160
- setContextDirty(context, initialStylingValues.length > 1);
161
- if (initialStaticClasses) {
162
- 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);
163
436
  }
164
- 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;
165
472
  }
166
473
  /**
167
474
  * Sets and resolves all `multi` styling on an `StylingContext` so that they can be
168
- * applied to the element once `renderStyleAndClassBindings` is called.
475
+ * applied to the element once `renderStyling` is called.
169
476
  *
170
477
  * All missing styles/class (any values that are not provided in the new `styles`
171
478
  * or `classes` params) will resolve to `null` within their respective positions
@@ -175,11 +482,14 @@ export function createStylingContextTemplate(initialClassDeclarations, initialSt
175
482
  * newly provided style values.
176
483
  * @param {?} classesInput The key/value map of CSS class names that will be used for the update.
177
484
  * @param {?=} stylesInput The key/value map of CSS styles that will be used for the update.
485
+ * @param {?=} directiveRef
178
486
  * @return {?}
179
487
  */
180
- export function updateStylingMap(context, classesInput, stylesInput) {
488
+ export function updateStylingMap(context, classesInput, stylesInput, directiveRef) {
181
489
  stylesInput = stylesInput || null;
182
490
  /** @type {?} */
491
+ const directiveIndex = getDirectiveIndexFromRegistry(context, directiveRef || null);
492
+ /** @type {?} */
183
493
  const element = (/** @type {?} */ ((/** @type {?} */ (context[5 /* ElementPosition */]))));
184
494
  /** @type {?} */
185
495
  const classesPlayerBuilder = classesInput instanceof BoundPlayerFactory ?
@@ -198,15 +508,15 @@ export function updateStylingMap(context, classesInput, stylesInput) {
198
508
  // early exit (this is what's done to avoid using ctx.bind() to cache the value)
199
509
  /** @type {?} */
200
510
  const ignoreAllClassUpdates = limitToSingleClasses(context) || classesValue === NO_CHANGE ||
201
- classesValue === context[6 /* PreviousOrCachedMultiClassValue */];
511
+ classesValue === context[6 /* CachedClassValueOrInitialClassString */];
202
512
  /** @type {?} */
203
- const ignoreAllStyleUpdates = stylesValue === NO_CHANGE || stylesValue === context[7 /* PreviousMultiStyleValue */];
513
+ const ignoreAllStyleUpdates = stylesValue === NO_CHANGE || stylesValue === context[7 /* CachedStyleValue */];
204
514
  if (ignoreAllClassUpdates && ignoreAllStyleUpdates)
205
515
  return;
206
- context[6 /* PreviousOrCachedMultiClassValue */] = classesValue;
207
- context[7 /* PreviousMultiStyleValue */] = stylesValue;
516
+ context[6 /* CachedClassValueOrInitialClassString */] = classesValue;
517
+ context[7 /* CachedStyleValue */] = stylesValue;
208
518
  /** @type {?} */
209
- let classNames = EMPTY_ARR;
519
+ let classNames = EMPTY_ARRAY;
210
520
  /** @type {?} */
211
521
  let applyAllClasses = false;
212
522
  /** @type {?} */
@@ -233,19 +543,19 @@ export function updateStylingMap(context, classesInput, stylesInput) {
233
543
  applyAllClasses = true;
234
544
  }
235
545
  else {
236
- classNames = classesValue ? Object.keys(classesValue) : EMPTY_ARR;
546
+ classNames = classesValue ? Object.keys(classesValue) : EMPTY_ARRAY;
237
547
  }
238
548
  }
239
549
  /** @type {?} */
240
550
  const classes = (/** @type {?} */ ((classesValue || EMPTY_OBJ)));
241
551
  /** @type {?} */
242
- const styleProps = stylesValue ? Object.keys(stylesValue) : EMPTY_ARR;
552
+ const styleProps = stylesValue ? Object.keys(stylesValue) : EMPTY_ARRAY;
243
553
  /** @type {?} */
244
554
  const styles = stylesValue || EMPTY_OBJ;
245
555
  /** @type {?} */
246
556
  const classesStartIndex = styleProps.length;
247
557
  /** @type {?} */
248
- const multiStartIndex = getMultiStartIndex(context);
558
+ let multiStartIndex = getMultiStartIndex(context);
249
559
  /** @type {?} */
250
560
  let dirty = false;
251
561
  /** @type {?} */
@@ -280,15 +590,19 @@ export function updateStylingMap(context, classesInput, stylesInput) {
280
590
  const value = getValue(context, ctxIndex);
281
591
  /** @type {?} */
282
592
  const flag = getPointers(context, ctxIndex);
283
- setPlayerBuilderIndex(context, ctxIndex, playerBuilderIndex);
593
+ setPlayerBuilderIndex(context, ctxIndex, playerBuilderIndex, directiveIndex);
284
594
  if (hasValueChanged(flag, value, newValue)) {
285
595
  setValue(context, ctxIndex, newValue);
286
596
  playerBuildersAreDirty = playerBuildersAreDirty || !!playerBuilderIndex;
287
597
  /** @type {?} */
288
598
  const initialValue = getInitialValue(context, flag);
289
- // there is no point in setting this to dirty if the previously
290
- // rendered value was being referenced by the initial style (or null)
291
- 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)) {
292
606
  setDirty(context, ctxIndex, true);
293
607
  dirty = true;
294
608
  }
@@ -308,7 +622,8 @@ export function updateStylingMap(context, classesInput, stylesInput) {
308
622
  /** @type {?} */
309
623
  const initialValue = getInitialValue(context, flagToCompare);
310
624
  setValue(context, ctxIndex, newValue);
311
- 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)) {
312
627
  setDirty(context, ctxIndex, true);
313
628
  playerBuildersAreDirty = playerBuildersAreDirty || !!playerBuilderIndex;
314
629
  dirty = true;
@@ -318,9 +633,9 @@ export function updateStylingMap(context, classesInput, stylesInput) {
318
633
  else {
319
634
  // we only care to do this if the insertion is in the middle
320
635
  /** @type {?} */
321
- const newFlag = prepareInitialFlag(newProp, isClassBased, getStyleSanitizer(context));
636
+ const newFlag = prepareInitialFlag(context, newProp, isClassBased, getStyleSanitizer(context, directiveIndex));
322
637
  playerBuildersAreDirty = playerBuildersAreDirty || !!playerBuilderIndex;
323
- insertNewMultiProperty(context, ctxIndex, isClassBased, newProp, newFlag, newValue, playerBuilderIndex);
638
+ insertNewMultiProperty(context, ctxIndex, isClassBased, newProp, newFlag, newValue, directiveIndex, playerBuilderIndex);
324
639
  dirty = true;
325
640
  }
326
641
  }
@@ -351,7 +666,7 @@ export function updateStylingMap(context, classesInput, stylesInput) {
351
666
  // is a valid animation player instruction.
352
667
  /** @type {?} */
353
668
  const playerBuilderIndex = isClassBased ? classesPlayerBuilderIndex : stylesPlayerBuilderIndex;
354
- setPlayerBuilderIndex(context, ctxIndex, playerBuilderIndex);
669
+ setPlayerBuilderIndex(context, ctxIndex, playerBuilderIndex, directiveIndex);
355
670
  dirty = true;
356
671
  }
357
672
  }
@@ -361,7 +676,7 @@ export function updateStylingMap(context, classesInput, stylesInput) {
361
676
  // were not detected in the context during the loop above. In that
362
677
  // case we want to add the new entries into the list
363
678
  /** @type {?} */
364
- const sanitizer = getStyleSanitizer(context);
679
+ const sanitizer = getStyleSanitizer(context, directiveIndex);
365
680
  while (propIndex < propLimit) {
366
681
  /** @type {?} */
367
682
  const isClassBased = propIndex >= classesStartIndex;
@@ -375,24 +690,42 @@ export function updateStylingMap(context, classesInput, stylesInput) {
375
690
  /** @type {?} */
376
691
  const value = isClassBased ? (applyAllClasses ? true : classes[prop]) : styles[prop];
377
692
  /** @type {?} */
378
- const flag = prepareInitialFlag(prop, isClassBased, sanitizer) | 1 /* Dirty */;
693
+ const flag = prepareInitialFlag(context, prop, isClassBased, sanitizer) | 1 /* Dirty */;
379
694
  /** @type {?} */
380
695
  const playerBuilderIndex = isClassBased ? classesPlayerBuilderIndex : stylesPlayerBuilderIndex;
381
- 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);
382
700
  dirty = true;
383
701
  }
384
702
  propIndex++;
385
703
  }
386
704
  if (dirty) {
387
705
  setContextDirty(context, true);
706
+ setDirectiveDirty(context, directiveIndex, true);
388
707
  }
389
708
  if (playerBuildersAreDirty) {
390
709
  setContextPlayersDirty(context, true);
391
710
  }
392
711
  }
393
712
  /**
394
- * Sets and resolves a single styling property/value on the provided `StylingContext` so
395
- * 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.
396
729
  *
397
730
  * Note that prop-level styling values are considered higher priority than any styling that
398
731
  * has been applied using `updateStylingMap`, therefore, when styling values are rendered
@@ -401,21 +734,40 @@ export function updateStylingMap(context, classesInput, stylesInput) {
401
734
  *
402
735
  * @param {?} context The styling context that will be updated with the
403
736
  * newly provided style value.
404
- * @param {?} index The index of the property which is being updated.
737
+ * @param {?} offset The index of the property which is being updated.
405
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).
406
743
  * @return {?}
407
744
  */
408
- 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) {
757
+ /** @type {?} */
758
+ const directiveIndex = getDirectiveIndexFromRegistry(context, directiveRef || null);
409
759
  /** @type {?} */
410
- const singleIndex = 8 /* SingleStylesStartPosition */ + index * 4 /* Size */;
760
+ const singleIndex = getSinglePropIndexValue(context, directiveIndex, offset, isClassBased);
411
761
  /** @type {?} */
412
762
  const currValue = getValue(context, singleIndex);
413
763
  /** @type {?} */
414
764
  const currFlag = getPointers(context, singleIndex);
415
765
  /** @type {?} */
766
+ const currDirective = getDirectiveIndexFromEntry(context, singleIndex);
767
+ /** @type {?} */
416
768
  const value = (input instanceof BoundPlayerFactory) ? input.value : input;
417
- // didn't change ... nothing to make a note of
418
- if (hasValueChanged(currFlag, currValue, value)) {
769
+ if (hasValueChanged(currFlag, currValue, value) &&
770
+ allowValueChange(currValue, value, currDirective, directiveIndex)) {
419
771
  /** @type {?} */
420
772
  const isClassBased = (currFlag & 2 /* Class */) === 2 /* Class */;
421
773
  /** @type {?} */
@@ -436,9 +788,18 @@ export function updateStyleProp(context, index, input) {
436
788
  /** @type {?} */
437
789
  const newIndex = setPlayerBuilder(context, playerBuilder, currPlayerIndex);
438
790
  playerBuilderIndex = playerBuilder ? newIndex : 0;
439
- setPlayerBuilderIndex(context, singleIndex, playerBuilderIndex);
440
791
  playerBuildersAreDirty = true;
441
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
+ }
442
803
  // the value will always get updated (even if the dirty flag is skipped)
443
804
  setValue(context, singleIndex, value);
444
805
  /** @type {?} */
@@ -458,6 +819,7 @@ export function updateStyleProp(context, index, input) {
458
819
  }
459
820
  setDirty(context, indexForMulti, multiDirty);
460
821
  setDirty(context, singleIndex, singleDirty);
822
+ setDirectiveDirty(context, directiveIndex, true);
461
823
  setContextDirty(context, true);
462
824
  }
463
825
  if (playerBuildersAreDirty) {
@@ -465,21 +827,6 @@ export function updateStyleProp(context, index, input) {
465
827
  }
466
828
  }
467
829
  }
468
- /**
469
- * This method will toggle the referenced CSS class (by the provided index)
470
- * within the given context.
471
- *
472
- * @param {?} context The styling context that will be updated with the
473
- * newly provided class value.
474
- * @param {?} index The index of the CSS class which is being updated.
475
- * @param {?} addOrRemove Whether or not to add or remove the CSS class
476
- * @return {?}
477
- */
478
- export function updateClassProp(context, index, addOrRemove) {
479
- /** @type {?} */
480
- const adjustedIndex = index + context[4 /* ClassOffsetPosition */];
481
- updateStyleProp(context, adjustedIndex, addOrRemove);
482
- }
483
830
  /**
484
831
  * Renders all queued styling using a renderer onto the given element.
485
832
  *
@@ -498,31 +845,44 @@ export function updateClassProp(context, index, addOrRemove) {
498
845
  * to this key/value map instead of being renderered via the renderer.
499
846
  * @param {?=} stylesStore if provided, the updated style values will be applied
500
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.
501
851
  * @return {?} number the total amount of players that got queued for animation (if any)
502
852
  */
503
- export function renderStyleAndClassBindings(context, renderer, rootOrView, isFirstRender, classesStore, stylesStore) {
853
+ export function renderStyling(context, renderer, rootOrView, isFirstRender, classesStore, stylesStore, directiveRef) {
504
854
  /** @type {?} */
505
855
  let totalPlayersQueued = 0;
506
- if (isContextDirty(context)) {
856
+ /** @type {?} */
857
+ const targetDirectiveIndex = getDirectiveIndexFromRegistry(context, directiveRef || null);
858
+ if (isContextDirty(context) && isDirectiveDirty(context, targetDirectiveIndex)) {
507
859
  /** @type {?} */
508
- const flushPlayerBuilders = context[3 /* MasterFlagPosition */] & 8 /* PlayerBuildersDirty */;
860
+ const flushPlayerBuilders = context[0 /* MasterFlagPosition */] & 8 /* PlayerBuildersDirty */;
509
861
  /** @type {?} */
510
862
  const native = (/** @type {?} */ (context[5 /* ElementPosition */]));
511
863
  /** @type {?} */
512
864
  const multiStartIndex = getMultiStartIndex(context);
513
865
  /** @type {?} */
514
- const styleSanitizer = getStyleSanitizer(context);
515
- /** @type {?} */
516
866
  const onlySingleClasses = limitToSingleClasses(context);
517
- 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 */) {
518
870
  // there is no point in rendering styles that have not changed on screen
519
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
+ }
520
880
  /** @type {?} */
521
881
  const prop = getProp(context, i);
522
882
  /** @type {?} */
523
883
  const value = getValue(context, i);
524
884
  /** @type {?} */
525
- const flag = getPointers(context, i);
885
+ const styleSanitizer = (flag & 4 /* Sanitize */) ? getStyleSanitizer(context, directiveIndex) : null;
526
886
  /** @type {?} */
527
887
  const playerBuilder = getPlayerBuilder(context, i);
528
888
  /** @type {?} */
@@ -548,7 +908,9 @@ export function renderStyleAndClassBindings(context, renderer, rootOrView, isFir
548
908
  // note that this should always be a falsy check since `false` is used
549
909
  // for both class and style comparisons (styles can't be false and false
550
910
  // classes are turned off and should therefore defer to their initial values)
551
- 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) {
552
914
  valueToApply = getInitialValue(context, flag);
553
915
  }
554
916
  // if the first render is true then we do not want to start applying falsy
@@ -562,9 +924,7 @@ export function renderStyleAndClassBindings(context, renderer, rootOrView, isFir
562
924
  setClass(native, prop, valueToApply ? true : false, renderer, classesStore, playerBuilder);
563
925
  }
564
926
  else {
565
- /** @type {?} */
566
- const sanitizer = (flag & 4 /* Sanitize */) ? styleSanitizer : null;
567
- setStyle(native, prop, (/** @type {?} */ (valueToApply)), renderer, sanitizer, stylesStore, playerBuilder);
927
+ setStyle(native, prop, (/** @type {?} */ (valueToApply)), renderer, styleSanitizer, stylesStore, playerBuilder);
568
928
  }
569
929
  }
570
930
  setDirty(context, i, false);
@@ -606,7 +966,8 @@ export function renderStyleAndClassBindings(context, renderer, rootOrView, isFir
606
966
  }
607
967
  setContextPlayersDirty(context, false);
608
968
  }
609
- setContextDirty(context, false);
969
+ setDirectiveDirty(context, targetDirectiveIndex, false);
970
+ setContextDirty(context, stillDirty);
610
971
  }
611
972
  return totalPlayersQueued;
612
973
  }
@@ -636,6 +997,8 @@ export function setStyle(native, prop, value, renderer, sanitizer, store, player
636
997
  }
637
998
  }
638
999
  else if (value) {
1000
+ value = value.toString(); // opacity, z-index and flexbox all have number values which may not
1001
+ // assign as numbers
639
1002
  ngDevMode && ngDevMode.rendererSetStyle++;
640
1003
  isProceduralRenderer(renderer) ?
641
1004
  renderer.setStyle(native, prop, value, RendererStyleFlags3.DashCase) :
@@ -682,6 +1045,20 @@ function setClass(native, className, add, renderer, store, playerBuilder) {
682
1045
  native['classList'].remove(className);
683
1046
  }
684
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
+ }
685
1062
  /**
686
1063
  * @param {?} context
687
1064
  * @param {?} index
@@ -690,7 +1067,7 @@ function setClass(native, className, add, renderer, store, playerBuilder) {
690
1067
  */
691
1068
  function setDirty(context, index, isDirtyYes) {
692
1069
  /** @type {?} */
693
- const adjustedIndex = index >= 8 /* SingleStylesStartPosition */ ? (index + 0 /* FlagsOffset */) : index;
1070
+ const adjustedIndex = index >= 9 /* SingleStylesStartPosition */ ? (index + 0 /* FlagsOffset */) : index;
694
1071
  if (isDirtyYes) {
695
1072
  ((/** @type {?} */ (context[adjustedIndex]))) |= 1 /* Dirty */;
696
1073
  }
@@ -705,7 +1082,7 @@ function setDirty(context, index, isDirtyYes) {
705
1082
  */
706
1083
  function isDirty(context, index) {
707
1084
  /** @type {?} */
708
- const adjustedIndex = index >= 8 /* SingleStylesStartPosition */ ? (index + 0 /* FlagsOffset */) : index;
1085
+ const adjustedIndex = index >= 9 /* SingleStylesStartPosition */ ? (index + 0 /* FlagsOffset */) : index;
709
1086
  return (((/** @type {?} */ (context[adjustedIndex]))) & 1 /* Dirty */) == 1 /* Dirty */;
710
1087
  }
711
1088
  /**
@@ -713,9 +1090,9 @@ function isDirty(context, index) {
713
1090
  * @param {?} index
714
1091
  * @return {?}
715
1092
  */
716
- export function isClassBased(context, index) {
1093
+ export function isClassBasedValue(context, index) {
717
1094
  /** @type {?} */
718
- const adjustedIndex = index >= 8 /* SingleStylesStartPosition */ ? (index + 0 /* FlagsOffset */) : index;
1095
+ const adjustedIndex = index >= 9 /* SingleStylesStartPosition */ ? (index + 0 /* FlagsOffset */) : index;
719
1096
  return (((/** @type {?} */ (context[adjustedIndex]))) & 2 /* Class */) == 2 /* Class */;
720
1097
  }
721
1098
  /**
@@ -725,7 +1102,7 @@ export function isClassBased(context, index) {
725
1102
  */
726
1103
  function isSanitizable(context, index) {
727
1104
  /** @type {?} */
728
- const adjustedIndex = index >= 8 /* SingleStylesStartPosition */ ? (index + 0 /* FlagsOffset */) : index;
1105
+ const adjustedIndex = index >= 9 /* SingleStylesStartPosition */ ? (index + 0 /* FlagsOffset */) : index;
729
1106
  return (((/** @type {?} */ (context[adjustedIndex]))) & 4 /* Sanitize */) == 4 /* Sanitize */;
730
1107
  }
731
1108
  /**
@@ -735,8 +1112,8 @@ function isSanitizable(context, index) {
735
1112
  * @return {?}
736
1113
  */
737
1114
  function pointers(configFlag, staticIndex, dynamicIndex) {
738
- return (configFlag & 31 /* BitMask */) | (staticIndex << 5 /* BitCountSize */) |
739
- (dynamicIndex << (14 /* BitCountSize */ + 5 /* BitCountSize */));
1115
+ return (configFlag & 63 /* BitMask */) | (staticIndex << 6 /* BitCountSize */) |
1116
+ (dynamicIndex << (14 /* BitCountSize */ + 6 /* BitCountSize */));
740
1117
  }
741
1118
  /**
742
1119
  * @param {?} context
@@ -746,14 +1123,19 @@ function pointers(configFlag, staticIndex, dynamicIndex) {
746
1123
  function getInitialValue(context, flag) {
747
1124
  /** @type {?} */
748
1125
  const index = getInitialIndex(flag);
749
- 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];
750
1132
  }
751
1133
  /**
752
1134
  * @param {?} flag
753
1135
  * @return {?}
754
1136
  */
755
1137
  function getInitialIndex(flag) {
756
- return (flag >> 5 /* BitCountSize */) & 16383 /* BitMask */;
1138
+ return (flag >> 6 /* BitCountSize */) & 16383 /* BitMask */;
757
1139
  }
758
1140
  /**
759
1141
  * @param {?} flag
@@ -761,22 +1143,15 @@ function getInitialIndex(flag) {
761
1143
  */
762
1144
  function getMultiOrSingleIndex(flag) {
763
1145
  /** @type {?} */
764
- const index = (flag >> (14 /* BitCountSize */ + 5 /* BitCountSize */)) & 16383 /* BitMask */;
765
- return index >= 8 /* SingleStylesStartPosition */ ? index : -1;
1146
+ const index = (flag >> (14 /* BitCountSize */ + 6 /* BitCountSize */)) & 16383 /* BitMask */;
1147
+ return index >= 9 /* SingleStylesStartPosition */ ? index : -1;
766
1148
  }
767
1149
  /**
768
1150
  * @param {?} context
769
1151
  * @return {?}
770
1152
  */
771
1153
  function getMultiStartIndex(context) {
772
- return (/** @type {?} */ (getMultiOrSingleIndex(context[3 /* MasterFlagPosition */])));
773
- }
774
- /**
775
- * @param {?} context
776
- * @return {?}
777
- */
778
- function getStyleSanitizer(context) {
779
- return context[1 /* StyleSanitizerPosition */];
1154
+ return (/** @type {?} */ (getMultiOrSingleIndex(context[0 /* MasterFlagPosition */])));
780
1155
  }
781
1156
  /**
782
1157
  * @param {?} context
@@ -804,7 +1179,7 @@ function setValue(context, index, value) {
804
1179
  */
805
1180
  function hasPlayerBuilderChanged(context, builder, index) {
806
1181
  /** @type {?} */
807
- const playerContext = (/** @type {?} */ (context[0 /* PlayerContext */]));
1182
+ const playerContext = (/** @type {?} */ (context[8 /* PlayerContext */]));
808
1183
  if (builder) {
809
1184
  if (!playerContext || index === 0) {
810
1185
  return true;
@@ -823,7 +1198,7 @@ function hasPlayerBuilderChanged(context, builder, index) {
823
1198
  */
824
1199
  function setPlayerBuilder(context, builder, insertionIndex) {
825
1200
  /** @type {?} */
826
- let playerContext = context[0 /* PlayerContext */] || allocPlayerContext(context);
1201
+ let playerContext = context[8 /* PlayerContext */] || allocPlayerContext(context);
827
1202
  if (insertionIndex > 0) {
828
1203
  playerContext[insertionIndex] = builder;
829
1204
  }
@@ -835,14 +1210,25 @@ function setPlayerBuilder(context, builder, insertionIndex) {
835
1210
  }
836
1211
  return insertionIndex;
837
1212
  }
1213
+ /**
1214
+ * @param {?} directiveIndex
1215
+ * @param {?} playerIndex
1216
+ * @return {?}
1217
+ */
1218
+ export function directiveOwnerPointers(directiveIndex, playerIndex) {
1219
+ return (playerIndex << 16 /* BitCountSize */) | directiveIndex;
1220
+ }
838
1221
  /**
839
1222
  * @param {?} context
840
1223
  * @param {?} index
841
1224
  * @param {?} playerBuilderIndex
1225
+ * @param {?} directiveIndex
842
1226
  * @return {?}
843
1227
  */
844
- function setPlayerBuilderIndex(context, index, playerBuilderIndex) {
845
- 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;
846
1232
  }
847
1233
  /**
848
1234
  * @param {?} context
@@ -850,7 +1236,12 @@ function setPlayerBuilderIndex(context, index, playerBuilderIndex) {
850
1236
  * @return {?}
851
1237
  */
852
1238
  function getPlayerBuilderIndex(context, index) {
853
- 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;
854
1245
  }
855
1246
  /**
856
1247
  * @param {?} context
@@ -862,7 +1253,7 @@ function getPlayerBuilder(context, index) {
862
1253
  const playerBuilderIndex = getPlayerBuilderIndex(context, index);
863
1254
  if (playerBuilderIndex) {
864
1255
  /** @type {?} */
865
- const playerContext = context[0 /* PlayerContext */];
1256
+ const playerContext = context[8 /* PlayerContext */];
866
1257
  if (playerContext) {
867
1258
  return (/** @type {?} */ (playerContext[playerBuilderIndex]));
868
1259
  }
@@ -877,7 +1268,7 @@ function getPlayerBuilder(context, index) {
877
1268
  */
878
1269
  function setFlag(context, index, flag) {
879
1270
  /** @type {?} */
880
- const adjustedIndex = index === 3 /* MasterFlagPosition */ ? index : (index + 0 /* FlagsOffset */);
1271
+ const adjustedIndex = index === 0 /* MasterFlagPosition */ ? index : (index + 0 /* FlagsOffset */);
881
1272
  context[adjustedIndex] = flag;
882
1273
  }
883
1274
  /**
@@ -887,7 +1278,7 @@ function setFlag(context, index, flag) {
887
1278
  */
888
1279
  function getPointers(context, index) {
889
1280
  /** @type {?} */
890
- const adjustedIndex = index === 3 /* MasterFlagPosition */ ? index : (index + 0 /* FlagsOffset */);
1281
+ const adjustedIndex = index === 0 /* MasterFlagPosition */ ? index : (index + 0 /* FlagsOffset */);
891
1282
  return (/** @type {?} */ (context[adjustedIndex]));
892
1283
  }
893
1284
  /**
@@ -911,14 +1302,14 @@ export function getProp(context, index) {
911
1302
  * @return {?}
912
1303
  */
913
1304
  export function isContextDirty(context) {
914
- return isDirty(context, 3 /* MasterFlagPosition */);
1305
+ return isDirty(context, 0 /* MasterFlagPosition */);
915
1306
  }
916
1307
  /**
917
1308
  * @param {?} context
918
1309
  * @return {?}
919
1310
  */
920
1311
  export function limitToSingleClasses(context) {
921
- return context[3 /* MasterFlagPosition */] & 16 /* OnlyProcessSingleClasses */;
1312
+ return context[0 /* MasterFlagPosition */] & 16 /* OnlyProcessSingleClasses */;
922
1313
  }
923
1314
  /**
924
1315
  * @param {?} context
@@ -926,7 +1317,7 @@ export function limitToSingleClasses(context) {
926
1317
  * @return {?}
927
1318
  */
928
1319
  export function setContextDirty(context, isDirtyYes) {
929
- setDirty(context, 3 /* MasterFlagPosition */, isDirtyYes);
1320
+ setDirty(context, 0 /* MasterFlagPosition */, isDirtyYes);
930
1321
  }
931
1322
  /**
932
1323
  * @param {?} context
@@ -935,10 +1326,10 @@ export function setContextDirty(context, isDirtyYes) {
935
1326
  */
936
1327
  export function setContextPlayersDirty(context, isDirtyYes) {
937
1328
  if (isDirtyYes) {
938
- ((/** @type {?} */ (context[3 /* MasterFlagPosition */]))) |= 8 /* PlayerBuildersDirty */;
1329
+ ((/** @type {?} */ (context[0 /* MasterFlagPosition */]))) |= 8 /* PlayerBuildersDirty */;
939
1330
  }
940
1331
  else {
941
- ((/** @type {?} */ (context[3 /* MasterFlagPosition */]))) &= ~8 /* PlayerBuildersDirty */;
1332
+ ((/** @type {?} */ (context[0 /* MasterFlagPosition */]))) &= ~8 /* PlayerBuildersDirty */;
942
1333
  }
943
1334
  }
944
1335
  /**
@@ -997,11 +1388,15 @@ function swapMultiContextEntries(context, indexA, indexB) {
997
1388
  setValue(context, indexA, getValue(context, indexB));
998
1389
  setProp(context, indexA, getProp(context, indexB));
999
1390
  setFlag(context, indexA, getPointers(context, indexB));
1000
- 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);
1001
1396
  setValue(context, indexB, tmpValue);
1002
1397
  setProp(context, indexB, tmpProp);
1003
1398
  setFlag(context, indexB, tmpFlag);
1004
- setPlayerBuilderIndex(context, indexB, tmpPlayerBuilderIndex);
1399
+ setPlayerBuilderIndex(context, indexB, tmpPlayerBuilderIndex, directiveIndexA);
1005
1400
  }
1006
1401
  /**
1007
1402
  * @param {?} context
@@ -1021,7 +1416,7 @@ function updateSinglePointerValues(context, indexStartPosition) {
1021
1416
  const initialIndexForSingle = getInitialIndex(singleFlag);
1022
1417
  /** @type {?} */
1023
1418
  const flagValue = (isDirty(context, singleIndex) ? 1 /* Dirty */ : 0 /* None */) |
1024
- (isClassBased(context, singleIndex) ? 2 /* Class */ : 0 /* None */) |
1419
+ (isClassBasedValue(context, singleIndex) ? 2 /* Class */ : 0 /* None */) |
1025
1420
  (isSanitizable(context, singleIndex) ? 4 /* Sanitize */ : 0 /* None */);
1026
1421
  /** @type {?} */
1027
1422
  const updatedFlag = pointers(flagValue, initialIndexForSingle, i);
@@ -1036,14 +1431,16 @@ function updateSinglePointerValues(context, indexStartPosition) {
1036
1431
  * @param {?} name
1037
1432
  * @param {?} flag
1038
1433
  * @param {?} value
1434
+ * @param {?} directiveIndex
1039
1435
  * @param {?} playerIndex
1040
1436
  * @return {?}
1041
1437
  */
1042
- function insertNewMultiProperty(context, index, classBased, name, flag, value, playerIndex) {
1438
+ function insertNewMultiProperty(context, index, classBased, name, flag, value, directiveIndex, playerIndex) {
1043
1439
  /** @type {?} */
1044
1440
  const doShift = index < context.length;
1045
1441
  // prop does not exist in the list, add it in
1046
- 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);
1047
1444
  if (doShift) {
1048
1445
  // because the value was inserted midway into the array then we
1049
1446
  // need to update all the shifted multi values' single value
@@ -1063,19 +1460,28 @@ function valueExists(value, isClassBased) {
1063
1460
  return value !== null;
1064
1461
  }
1065
1462
  /**
1066
- * @param {?} name
1067
- * @param {?} isClassBased
1463
+ * @param {?} context
1464
+ * @param {?} prop
1465
+ * @param {?} entryIsClassBased
1068
1466
  * @param {?=} sanitizer
1069
1467
  * @return {?}
1070
1468
  */
1071
- function prepareInitialFlag(name, isClassBased, sanitizer) {
1072
- if (isClassBased) {
1073
- 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);
1074
1478
  }
1075
- else if (sanitizer && sanitizer(name)) {
1076
- return 4 /* Sanitize */;
1479
+ else {
1480
+ initialIndex =
1481
+ getInitialStylingValuesIndexOf(context[2 /* InitialStyleValuesPosition */], prop);
1077
1482
  }
1078
- return 0 /* None */;
1483
+ initialIndex = initialIndex > 0 ? (initialIndex + 1 /* ValueOffset */) : 0;
1484
+ return pointers(flag, initialIndex, 0);
1079
1485
  }
1080
1486
  /**
1081
1487
  * @param {?} flag
@@ -1173,4 +1579,278 @@ if (false) {
1173
1579
  */
1174
1580
  ClassAndStylePlayerBuilder.prototype._type;
1175
1581
  }
1176
- //# 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 {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\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 | LView,\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 */\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    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\nexport function 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\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  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"]}