@angular/core 8.0.0 → 8.1.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (191) hide show
  1. package/bundles/core-testing.umd.js +35 -9
  2. package/bundles/core-testing.umd.js.map +1 -1
  3. package/bundles/core-testing.umd.min.js +10 -10
  4. package/bundles/core-testing.umd.min.js.map +1 -1
  5. package/bundles/core.umd.js +11356 -9352
  6. package/bundles/core.umd.js.map +1 -1
  7. package/bundles/core.umd.min.js +201 -139
  8. package/bundles/core.umd.min.js.map +1 -1
  9. package/core.d.ts +1302 -404
  10. package/core.metadata.json +1 -1
  11. package/esm2015/core.js +2 -3
  12. package/esm2015/index.js +2 -2
  13. package/esm2015/public_api.js +2 -2
  14. package/esm2015/src/application_ref.js +7 -1
  15. package/esm2015/src/codegen_private_exports.js +2 -2
  16. package/esm2015/src/compiler/compiler_facade_interface.js +1 -1
  17. package/esm2015/src/core.js +4 -4
  18. package/esm2015/src/core_private_export.js +3 -1
  19. package/esm2015/src/core_render3_private_export.js +5 -3
  20. package/esm2015/src/debug/debug_node.js +4 -4
  21. package/esm2015/src/di/index.js +3 -3
  22. package/esm2015/src/di/injector.js +24 -96
  23. package/esm2015/src/di/injector_compatibility.js +103 -6
  24. package/esm2015/src/di/interface/defs.js +24 -3
  25. package/esm2015/src/di/r3_injector.js +82 -49
  26. package/esm2015/src/di/reflective_injector.js +3 -2
  27. package/esm2015/src/di.js +1 -1
  28. package/esm2015/src/i18n/locale_data.js +61 -0
  29. package/esm2015/src/i18n/locale_data_api.js +53 -0
  30. package/esm2015/src/i18n/locale_en.js +51 -0
  31. package/esm2015/src/i18n/localization.js +37 -0
  32. package/esm2015/src/linker/ng_module_factory_loader.js +4 -52
  33. package/esm2015/src/linker/ng_module_factory_registration.js +83 -0
  34. package/esm2015/src/metadata/ng_module.js +6 -1
  35. package/esm2015/src/metadata/resource_loading.js +2 -2
  36. package/esm2015/src/reflection/reflection_capabilities.js +14 -3
  37. package/esm2015/src/render3/assert.js +3 -2
  38. package/esm2015/src/render3/component.js +11 -5
  39. package/esm2015/src/render3/debug.js +23 -15
  40. package/esm2015/src/render3/definition.js +12 -2
  41. package/esm2015/src/render3/errors.js +29 -1
  42. package/esm2015/src/render3/features/inherit_definition_feature.js +51 -37
  43. package/esm2015/src/render3/fields.js +3 -1
  44. package/esm2015/src/render3/i18n.js +76 -465
  45. package/esm2015/src/render3/index.js +3 -3
  46. package/esm2015/src/render3/instructions/all.js +9 -4
  47. package/esm2015/src/render3/instructions/attribute.js +28 -0
  48. package/esm2015/src/render3/instructions/attribute_interpolation.js +376 -0
  49. package/esm2015/src/render3/instructions/container.js +17 -16
  50. package/esm2015/src/render3/instructions/element.js +57 -35
  51. package/esm2015/src/render3/instructions/element_container.js +9 -8
  52. package/esm2015/src/render3/instructions/embedded_view.js +9 -12
  53. package/esm2015/src/render3/instructions/interpolation.js +375 -0
  54. package/esm2015/src/render3/instructions/listener.js +3 -2
  55. package/esm2015/src/render3/instructions/projection.js +6 -6
  56. package/esm2015/src/render3/instructions/property.js +10 -4
  57. package/esm2015/src/render3/instructions/property_interpolation.js +49 -382
  58. package/esm2015/src/render3/instructions/shared.js +82 -118
  59. package/esm2015/src/render3/instructions/styling.js +189 -236
  60. package/esm2015/src/render3/instructions/text.js +8 -7
  61. package/esm2015/src/render3/instructions/text_interpolation.js +357 -0
  62. package/esm2015/src/render3/interfaces/container.js +9 -5
  63. package/esm2015/src/render3/interfaces/definition.js +12 -6
  64. package/esm2015/src/render3/interfaces/node.js +20 -8
  65. package/esm2015/src/render3/interfaces/styling.js +16 -15
  66. package/esm2015/src/render3/interfaces/view.js +2 -2
  67. package/esm2015/src/render3/jit/directive.js +14 -5
  68. package/esm2015/src/render3/jit/environment.js +30 -15
  69. package/esm2015/src/render3/jit/module.js +38 -19
  70. package/esm2015/src/render3/ng_module_ref.js +39 -3
  71. package/esm2015/src/render3/node_manipulation.js +45 -43
  72. package/esm2015/src/render3/node_selector_matcher.js +14 -13
  73. package/esm2015/src/render3/query.js +77 -61
  74. package/esm2015/src/render3/state.js +33 -6
  75. package/esm2015/src/render3/styling/class_and_style_bindings.js +91 -79
  76. package/esm2015/src/render3/styling/host_instructions_queue.js +8 -5
  77. package/esm2015/src/render3/styling/shared.js +2 -2
  78. package/esm2015/src/render3/styling/util.js +2 -2
  79. package/esm2015/src/render3/styling_next/bindings.js +602 -0
  80. package/esm2015/src/render3/styling_next/instructions.js +366 -0
  81. package/esm2015/src/render3/styling_next/interfaces.js +374 -0
  82. package/esm2015/src/render3/styling_next/map_based_bindings.js +408 -0
  83. package/esm2015/src/render3/styling_next/state.js +51 -0
  84. package/esm2015/src/render3/styling_next/styling_debug.js +291 -0
  85. package/esm2015/src/render3/styling_next/util.js +259 -0
  86. package/esm2015/src/render3/util/attrs_utils.js +4 -3
  87. package/esm2015/src/render3/util/debug_utils.js +18 -0
  88. package/esm2015/src/render3/util/view_traversal_utils.js +2 -2
  89. package/esm2015/src/render3/view_engine_compatibility.js +24 -10
  90. package/esm2015/src/sanitization/sanitization.js +17 -7
  91. package/esm2015/src/sanitization/style_sanitizer.js +11 -1
  92. package/esm2015/src/util/ng_dev_mode.js +7 -3
  93. package/esm2015/src/version.js +1 -1
  94. package/esm2015/src/view/ng_module.js +3 -3
  95. package/esm2015/src/view/util.js +2 -2
  96. package/esm2015/testing/src/r3_test_bed_compiler.js +44 -12
  97. package/esm5/core.js +2 -3
  98. package/esm5/src/application_ref.js +6 -1
  99. package/esm5/src/codegen_private_exports.js +2 -2
  100. package/esm5/src/compiler/compiler_facade_interface.js +1 -1
  101. package/esm5/src/core_private_export.js +3 -1
  102. package/esm5/src/core_render3_private_export.js +5 -3
  103. package/esm5/src/debug/debug_node.js +4 -4
  104. package/esm5/src/di/index.js +3 -3
  105. package/esm5/src/di/injector.js +14 -74
  106. package/esm5/src/di/injector_compatibility.js +77 -6
  107. package/esm5/src/di/interface/defs.js +24 -3
  108. package/esm5/src/di/r3_injector.js +60 -37
  109. package/esm5/src/di/reflective_injector.js +3 -2
  110. package/esm5/src/i18n/locale_data.js +38 -0
  111. package/esm5/src/i18n/locale_data_api.js +46 -0
  112. package/esm5/src/i18n/locale_en.js +39 -0
  113. package/esm5/src/i18n/localization.js +29 -0
  114. package/esm5/src/linker/ng_module_factory_loader.js +4 -32
  115. package/esm5/src/linker/ng_module_factory_registration.js +50 -0
  116. package/esm5/src/metadata/ng_module.js +1 -1
  117. package/esm5/src/metadata/resource_loading.js +2 -2
  118. package/esm5/src/reflection/reflection_capabilities.js +14 -3
  119. package/esm5/src/render3/assert.js +2 -1
  120. package/esm5/src/render3/component.js +10 -4
  121. package/esm5/src/render3/debug.js +17 -10
  122. package/esm5/src/render3/definition.js +8 -2
  123. package/esm5/src/render3/errors.js +14 -1
  124. package/esm5/src/render3/features/inherit_definition_feature.js +41 -36
  125. package/esm5/src/render3/fields.js +2 -1
  126. package/esm5/src/render3/i18n.js +67 -437
  127. package/esm5/src/render3/index.js +3 -3
  128. package/esm5/src/render3/instructions/all.js +6 -1
  129. package/esm5/src/render3/instructions/attribute.js +22 -0
  130. package/esm5/src/render3/instructions/attribute_interpolation.js +346 -0
  131. package/esm5/src/render3/instructions/container.js +16 -15
  132. package/esm5/src/render3/instructions/element.js +43 -32
  133. package/esm5/src/render3/instructions/element_container.js +9 -8
  134. package/esm5/src/render3/instructions/embedded_view.js +8 -11
  135. package/esm5/src/render3/instructions/interpolation.js +243 -0
  136. package/esm5/src/render3/instructions/listener.js +3 -2
  137. package/esm5/src/render3/instructions/projection.js +6 -6
  138. package/esm5/src/render3/instructions/property.js +10 -4
  139. package/esm5/src/render3/instructions/property_interpolation.js +40 -254
  140. package/esm5/src/render3/instructions/shared.js +70 -105
  141. package/esm5/src/render3/instructions/styling.js +167 -209
  142. package/esm5/src/render3/instructions/text.js +8 -7
  143. package/esm5/src/render3/instructions/text_interpolation.js +264 -0
  144. package/esm5/src/render3/interfaces/container.js +8 -2
  145. package/esm5/src/render3/interfaces/definition.js +1 -1
  146. package/esm5/src/render3/interfaces/node.js +1 -8
  147. package/esm5/src/render3/interfaces/styling.js +2 -2
  148. package/esm5/src/render3/interfaces/view.js +1 -1
  149. package/esm5/src/render3/jit/directive.js +12 -5
  150. package/esm5/src/render3/jit/environment.js +30 -15
  151. package/esm5/src/render3/jit/module.js +23 -18
  152. package/esm5/src/render3/ng_module_ref.js +37 -3
  153. package/esm5/src/render3/node_manipulation.js +39 -38
  154. package/esm5/src/render3/node_selector_matcher.js +14 -13
  155. package/esm5/src/render3/query.js +75 -53
  156. package/esm5/src/render3/state.js +29 -5
  157. package/esm5/src/render3/styling/class_and_style_bindings.js +79 -65
  158. package/esm5/src/render3/styling/host_instructions_queue.js +6 -3
  159. package/esm5/src/render3/styling/shared.js +2 -2
  160. package/esm5/src/render3/styling/util.js +2 -2
  161. package/esm5/src/render3/styling_next/bindings.js +446 -0
  162. package/esm5/src/render3/styling_next/instructions.js +277 -0
  163. package/esm5/src/render3/styling_next/interfaces.js +1 -0
  164. package/esm5/src/render3/styling_next/map_based_bindings.js +324 -0
  165. package/esm5/src/render3/styling_next/state.js +23 -0
  166. package/esm5/src/render3/styling_next/styling_debug.js +130 -0
  167. package/esm5/src/render3/styling_next/util.js +147 -0
  168. package/esm5/src/render3/util/attrs_utils.js +4 -3
  169. package/esm5/src/render3/util/debug_utils.js +11 -0
  170. package/esm5/src/render3/util/view_traversal_utils.js +2 -2
  171. package/esm5/src/render3/view_engine_compatibility.js +23 -10
  172. package/esm5/src/sanitization/sanitization.js +14 -6
  173. package/esm5/src/sanitization/style_sanitizer.js +1 -1
  174. package/esm5/src/util/ng_dev_mode.js +7 -3
  175. package/esm5/src/version.js +1 -1
  176. package/esm5/src/view/ng_module.js +3 -3
  177. package/esm5/src/view/util.js +2 -2
  178. package/esm5/testing/src/r3_test_bed_compiler.js +37 -11
  179. package/fesm2015/core.js +13481 -10733
  180. package/fesm2015/core.js.map +1 -1
  181. package/fesm2015/testing.js +43 -11
  182. package/fesm2015/testing.js.map +1 -1
  183. package/fesm5/core.js +11255 -9269
  184. package/fesm5/core.js.map +1 -1
  185. package/fesm5/testing.js +36 -10
  186. package/fesm5/testing.js.map +1 -1
  187. package/package.json +1 -1
  188. package/schematics/migrations/template-var-assignment/index.js +2 -2
  189. package/src/r3_symbols.d.ts +5 -1
  190. package/testing/testing.d.ts +1 -1
  191. package/testing.d.ts +1 -1
@@ -1,12 +1,15 @@
1
1
  import { assertEqual } from '../../util/assert';
2
2
  import { FLAGS, HEADER_OFFSET, RENDERER } from '../interfaces/view';
3
3
  import { getActiveDirectiveId, getActiveDirectiveSuperClassDepth, getLView, getPreviousOrParentTNode, getSelectedIndex } from '../state';
4
- import { getInitialClassNameValue, renderStyling, updateClassProp as updateElementClassProp, updateContextWithBindings, updateStyleProp as updateElementStyleProp, updateStylingMap } from '../styling/class_and_style_bindings';
4
+ import { getInitialClassNameValue, renderStyling, updateClassMap, updateClassProp as updateclassProp, updateContextWithBindings, updateStyleMap, updateStyleProp as updatestyleProp } from '../styling/class_and_style_bindings';
5
5
  import { enqueueHostInstruction, registerHostDirective } from '../styling/host_instructions_queue';
6
6
  import { BoundPlayerFactory } from '../styling/player_factory';
7
7
  import { DEFAULT_TEMPLATE_DIRECTIVE_INDEX } from '../styling/shared';
8
8
  import { getCachedStylingContext, setCachedStylingContext } from '../styling/state';
9
9
  import { allocateOrUpdateDirectiveIntoContext, createEmptyStylingContext, forceClassesAsString, forceStylesAsString, getStylingContextFromLView, hasClassInput, hasStyleInput } from '../styling/util';
10
+ import { classMap as newClassMap, classProp as newClassProp, styleMap as newStyleMap, styleProp as newStyleProp, stylingApply as newStylingApply, stylingInit as newStylingInit } from '../styling_next/instructions';
11
+ import { runtimeAllowOldStyling, runtimeIsNewStylingInUse } from '../styling_next/state';
12
+ import { getBindingNameFromIndex } from '../styling_next/util';
10
13
  import { NO_CHANGE } from '../tokens';
11
14
  import { renderStringify } from '../util/misc_utils';
12
15
  import { getRootContext } from '../util/view_traversal_utils';
@@ -19,18 +22,12 @@ import { scheduleTick, setInputsForProperty } from './shared';
19
22
  * The instructions present in this file are:
20
23
  *
21
24
  * Template level styling instructions:
22
- * - elementStyling
23
- * - elementStylingMap
24
- * - elementStyleProp
25
- * - elementClassProp
26
- * - elementStylingApply
27
- *
28
- * Host bindings level styling instructions:
29
- * - elementHostStyling
30
- * - elementHostStylingMap
31
- * - elementHostStyleProp
32
- * - elementHostClassProp
33
- * - elementHostStylingApply
25
+ * - styling
26
+ * - styleMap
27
+ * - classMap
28
+ * - styleProp
29
+ * - classProp
30
+ * - stylingApply
34
31
  */
35
32
  /**
36
33
  * Allocates style and class binding properties on the element during creation mode.
@@ -41,70 +38,54 @@ import { scheduleTick, setInputsForProperty } from './shared';
41
38
  * values to an element).
42
39
  *
43
40
  * @param classBindingNames An array containing bindable class names.
44
- * The `elementClassProp` instruction refers to the class name by index in
41
+ * The `classProp` instruction refers to the class name by index in
45
42
  * this array (i.e. `['foo', 'bar']` means `foo=0` and `bar=1`).
46
43
  * @param styleBindingNames An array containing bindable style properties.
47
- * The `elementStyleProp` instruction refers to the class name by index in
44
+ * The `styleProp` instruction refers to the class name by index in
48
45
  * this array (i.e. `['width', 'height']` means `width=0` and `height=1`).
49
46
  * @param styleSanitizer An optional sanitizer function that will be used to sanitize any CSS
50
47
  * style values that are applied to the element (during rendering).
51
48
  *
52
- * @codeGenApi
53
- */
54
- export function ɵɵelementStyling(classBindingNames, styleBindingNames, styleSanitizer) {
55
- var tNode = getPreviousOrParentTNode();
56
- if (!tNode.stylingTemplate) {
57
- tNode.stylingTemplate = createEmptyStylingContext();
58
- }
59
- // calling the function below ensures that the template's binding values
60
- // are applied as the first set of bindings into the context. If any other
61
- // styling bindings are set on the same element (by directives and/or
62
- // components) then they will be applied at the end of the `elementEnd`
63
- // instruction (because directives are created first before styling is
64
- // executed for a new element).
65
- initElementStyling(tNode, classBindingNames, styleBindingNames, styleSanitizer, DEFAULT_TEMPLATE_DIRECTIVE_INDEX);
66
- }
67
- /**
68
- * Allocates style and class binding properties on the host element during creation mode
69
- * within the host bindings function of a directive or component.
70
- *
71
- * This instruction is meant to be called during creation mode to register all
72
- * dynamic style and class host bindings on the host element of a directive or
73
- * component. Note that this is only used for binding values (see `elementHostAttrs`
74
- * to learn how to assign static styling values to the host element).
75
- *
76
- * @param classBindingNames An array containing bindable class names.
77
- * The `elementHostClassProp` instruction refers to the class name by index in
78
- * this array (i.e. `['foo', 'bar']` means `foo=0` and `bar=1`).
79
- * @param styleBindingNames An array containing bindable style properties.
80
- * The `elementHostStyleProp` instruction refers to the class name by index in
81
- * this array (i.e. `['width', 'height']` means `width=0` and `height=1`).
82
- * @param styleSanitizer An optional sanitizer function that will be used to sanitize any CSS
83
- * style values that are applied to the element (during rendering).
84
- * Note that the sanitizer instance itself is tied to the provided `directive` and
85
- * will not be used if the same property is assigned in another directive or
86
- * on the element directly.
49
+ * Note that this will allocate the provided style/class bindings to the host element if
50
+ * this function is called within a host binding.
87
51
  *
88
52
  * @codeGenApi
89
53
  */
90
- export function ɵɵelementHostStyling(classBindingNames, styleBindingNames, styleSanitizer) {
54
+ export function ɵɵstyling(classBindingNames, styleBindingNames, styleSanitizer) {
91
55
  var tNode = getPreviousOrParentTNode();
92
56
  if (!tNode.stylingTemplate) {
93
57
  tNode.stylingTemplate = createEmptyStylingContext();
94
58
  }
95
59
  var directiveStylingIndex = getActiveDirectiveStylingIndex();
96
- // despite the binding being applied in a queue (below), the allocation
97
- // of the directive into the context happens right away. The reason for
98
- // this is to retain the ordering of the directives (which is important
99
- // for the prioritization of bindings).
100
- allocateOrUpdateDirectiveIntoContext(tNode.stylingTemplate, directiveStylingIndex);
101
- var fns = tNode.onElementCreationFns = tNode.onElementCreationFns || [];
102
- fns.push(function () {
103
- initElementStyling(tNode, classBindingNames, styleBindingNames, styleSanitizer, directiveStylingIndex);
104
- registerHostDirective(tNode.stylingTemplate, directiveStylingIndex);
105
- });
60
+ if (directiveStylingIndex) {
61
+ // this is temporary hack to get the existing styling instructions to
62
+ // play ball with the new refactored implementation.
63
+ // TODO (matsko): remove this once the old implementation is not needed.
64
+ if (runtimeIsNewStylingInUse()) {
65
+ newStylingInit();
66
+ }
67
+ // despite the binding being applied in a queue (below), the allocation
68
+ // of the directive into the context happens right away. The reason for
69
+ // this is to retain the ordering of the directives (which is important
70
+ // for the prioritization of bindings).
71
+ allocateOrUpdateDirectiveIntoContext(tNode.stylingTemplate, directiveStylingIndex);
72
+ var fns = tNode.onElementCreationFns = tNode.onElementCreationFns || [];
73
+ fns.push(function () {
74
+ initStyling(tNode, classBindingNames, styleBindingNames, styleSanitizer, directiveStylingIndex);
75
+ registerHostDirective(tNode.stylingTemplate, directiveStylingIndex);
76
+ });
77
+ }
78
+ else {
79
+ // calling the function below ensures that the template's binding values
80
+ // are applied as the first set of bindings into the context. If any other
81
+ // styling bindings are set on the same element (by directives and/or
82
+ // components) then they will be applied at the end of the `elementEnd`
83
+ // instruction (because directives are created first before styling is
84
+ // executed for a new element).
85
+ initStyling(tNode, classBindingNames, styleBindingNames, styleSanitizer, DEFAULT_TEMPLATE_DIRECTIVE_INDEX);
86
+ }
106
87
  }
107
- function initElementStyling(tNode, classBindingNames, styleBindingNames, styleSanitizer, directiveStylingIndex) {
88
+ function initStyling(tNode, classBindingNames, styleBindingNames, styleSanitizer, directiveStylingIndex) {
108
89
  updateContextWithBindings(tNode.stylingTemplate, directiveStylingIndex, classBindingNames, styleBindingNames, styleSanitizer);
109
90
  }
110
91
  /**
@@ -112,64 +93,45 @@ function initElementStyling(tNode, classBindingNames, styleBindingNames, styleSa
112
93
  *
113
94
  * If the style value is falsy then it will be removed from the element
114
95
  * (or assigned a different value depending if there are any styles placed
115
- * on the element with `elementStylingMap` or any static styles that are
116
- * present from when the element was created with `elementStyling`).
96
+ * on the element with `styleMap` or any static styles that are
97
+ * present from when the element was created with `styling`).
117
98
  *
118
- * Note that the styling element is updated as part of `elementStylingApply`.
99
+ * Note that the styling element is updated as part of `stylingApply`.
119
100
  *
120
- * @param index Index of the element's with which styling is associated.
121
101
  * @param styleIndex Index of style to update. This index value refers to the
122
102
  * index of the style in the style bindings array that was passed into
123
- * `elementStyling`.
124
- * @param value New value to write (falsy to remove). Note that if a directive also
125
- * attempts to write to the same binding value (via `elementHostStyleProp`)
126
- * then it will only be able to do so if the binding value assigned via
127
- * `elementStyleProp` is falsy (or doesn't exist at all).
103
+ * `styling`.
104
+ * @param value New value to write (falsy to remove).
128
105
  * @param suffix Optional suffix. Used with scalar values to add unit such as `px`.
129
106
  * Note that when a suffix is provided then the underlying sanitizer will
130
107
  * be ignored.
131
108
  * @param forceOverride Whether or not to update the styling value immediately
132
109
  * (despite the other bindings possibly having priority)
133
110
  *
111
+ * Note that this will apply the provided style value to the host element if this function is called
112
+ * within a host binding.
113
+ *
134
114
  * @codeGenApi
135
115
  */
136
- export function ɵɵelementStyleProp(index, styleIndex, value, suffix, forceOverride) {
116
+ export function ɵɵstyleProp(styleIndex, value, suffix, forceOverride) {
117
+ var index = getSelectedIndex();
137
118
  var valueToAdd = resolveStylePropValue(value, suffix);
138
119
  var stylingContext = getStylingContext(index, getLView());
139
- updateElementStyleProp(stylingContext, styleIndex, valueToAdd, DEFAULT_TEMPLATE_DIRECTIVE_INDEX, forceOverride);
140
- }
141
- /**
142
- * Update a host style binding value on the host element within a component/directive.
143
- *
144
- * If the style value is falsy then it will be removed from the host element
145
- * (or assigned a different value depending if there are any styles placed
146
- * on the same element with `elementHostStylingMap` or any static styles that
147
- * are present from when the element was patched with `elementHostStyling`).
148
- *
149
- * Note that the styling applied to the host element once
150
- * `elementHostStylingApply` is called.
151
- *
152
- * @param styleIndex Index of style to update. This index value refers to the
153
- * index of the style in the style bindings array that was passed into
154
- * `elementHostStyling`.
155
- * @param value New value to write (falsy to remove). The value may or may not
156
- * be applied to the element depending on the template/component/directive
157
- * prioritization (see `interfaces/styling.ts`)
158
- * @param suffix Optional suffix. Used with scalar values to add unit such as `px`.
159
- * Note that when a suffix is provided then the underlying sanitizer will
160
- * be ignored.
161
- * @param forceOverride Whether or not to update the styling value immediately
162
- * (despite the other bindings possibly having priority)
163
- *
164
- * @codeGenApi
165
- */
166
- export function ɵɵelementHostStyleProp(styleIndex, value, suffix, forceOverride) {
167
120
  var directiveStylingIndex = getActiveDirectiveStylingIndex();
168
- var hostElementIndex = getSelectedIndex();
169
- var stylingContext = getStylingContext(hostElementIndex, getLView());
170
- var valueToAdd = resolveStylePropValue(value, suffix);
171
- var args = [stylingContext, styleIndex, valueToAdd, directiveStylingIndex, forceOverride];
172
- enqueueHostInstruction(stylingContext, directiveStylingIndex, updateElementStyleProp, args);
121
+ if (directiveStylingIndex) {
122
+ var args = [stylingContext, styleIndex, valueToAdd, directiveStylingIndex, forceOverride];
123
+ enqueueHostInstruction(stylingContext, directiveStylingIndex, updatestyleProp, args);
124
+ }
125
+ else {
126
+ updatestyleProp(stylingContext, styleIndex, valueToAdd, DEFAULT_TEMPLATE_DIRECTIVE_INDEX, forceOverride);
127
+ }
128
+ if (runtimeIsNewStylingInUse()) {
129
+ var prop = getBindingNameFromIndex(stylingContext, styleIndex, directiveStylingIndex, false);
130
+ // the reason why we cast the value as `boolean` is
131
+ // because the new styling refactor does not yet support
132
+ // sanitization or animation players.
133
+ newStyleProp(prop, value, suffix);
134
+ }
173
135
  }
174
136
  function resolveStylePropValue(value, suffix) {
175
137
  var valueToAdd = null;
@@ -194,53 +156,42 @@ function resolveStylePropValue(value, suffix) {
194
156
  *
195
157
  * This instruction is meant to handle the `[class.foo]="exp"` case and,
196
158
  * therefore, the class binding itself must already be allocated using
197
- * `elementStyling` within the creation block.
159
+ * `styling` within the creation block.
198
160
  *
199
- * @param index Index of the element's with which styling is associated.
200
161
  * @param classIndex Index of class to toggle. This index value refers to the
201
162
  * index of the class in the class bindings array that was passed into
202
- * `elementStyling` (which is meant to be called before this
163
+ * `styling` (which is meant to be called before this
203
164
  * function is).
204
165
  * @param value A true/false value which will turn the class on or off.
205
166
  * @param forceOverride Whether or not this value will be applied regardless
206
167
  * of where it is being set within the styling priority structure.
207
168
  *
208
- * @codeGenApi
209
- */
210
- export function ɵɵelementClassProp(index, classIndex, value, forceOverride) {
211
- var input = (value instanceof BoundPlayerFactory) ?
212
- value :
213
- booleanOrNull(value);
214
- var stylingContext = getStylingContext(index, getLView());
215
- updateElementClassProp(stylingContext, classIndex, input, DEFAULT_TEMPLATE_DIRECTIVE_INDEX, forceOverride);
216
- }
217
- /**
218
- * Update a class host binding for a directive's/component's host element within
219
- * the host bindings function.
220
- *
221
- * This instruction is meant to handle the `@HostBinding('class.foo')` case and,
222
- * therefore, the class binding itself must already be allocated using
223
- * `elementHostStyling` within the creation block.
224
- *
225
- * @param classIndex Index of class to toggle. This index value refers to the
226
- * index of the class in the class bindings array that was passed into
227
- * `elementHostStlying` (which is meant to be called before this
228
- * function is).
229
- * @param value A true/false value which will turn the class on or off.
230
- * @param forceOverride Whether or not this value will be applied regardless
231
- * of where it is being set within the stylings priority structure.
169
+ * Note that this will apply the provided class value to the host element if this function
170
+ * is called within a host binding.
232
171
  *
233
172
  * @codeGenApi
234
173
  */
235
- export function ɵɵelementHostClassProp(classIndex, value, forceOverride) {
236
- var directiveStylingIndex = getActiveDirectiveStylingIndex();
237
- var hostElementIndex = getSelectedIndex();
238
- var stylingContext = getStylingContext(hostElementIndex, getLView());
174
+ export function ɵɵclassProp(classIndex, value, forceOverride) {
175
+ var index = getSelectedIndex();
239
176
  var input = (value instanceof BoundPlayerFactory) ?
240
177
  value :
241
178
  booleanOrNull(value);
242
- var args = [stylingContext, classIndex, input, directiveStylingIndex, forceOverride];
243
- enqueueHostInstruction(stylingContext, directiveStylingIndex, updateElementClassProp, args);
179
+ var directiveStylingIndex = getActiveDirectiveStylingIndex();
180
+ var stylingContext = getStylingContext(index, getLView());
181
+ if (directiveStylingIndex) {
182
+ var args = [stylingContext, classIndex, input, directiveStylingIndex, forceOverride];
183
+ enqueueHostInstruction(stylingContext, directiveStylingIndex, updateclassProp, args);
184
+ }
185
+ else {
186
+ updateclassProp(stylingContext, classIndex, input, DEFAULT_TEMPLATE_DIRECTIVE_INDEX, forceOverride);
187
+ }
188
+ if (runtimeIsNewStylingInUse()) {
189
+ var prop = getBindingNameFromIndex(stylingContext, classIndex, directiveStylingIndex, true);
190
+ // the reason why we cast the value as `boolean` is
191
+ // because the new styling refactor does not yet support
192
+ // sanitization or animation players.
193
+ newClassProp(prop, input);
194
+ }
244
195
  }
245
196
  function booleanOrNull(value) {
246
197
  if (typeof value === 'boolean')
@@ -248,104 +199,106 @@ function booleanOrNull(value) {
248
199
  return value ? true : null;
249
200
  }
250
201
  /**
251
- * Update style and/or class bindings using object literals on an element.
202
+ * Update style bindings using an object literal on an element.
252
203
  *
253
- * This instruction is meant to apply styling via the `[style]="exp"` and `[class]="exp"` template
254
- * bindings. When styles/classes are applied to the element they will then be updated with
255
- * respect to any styles/classes set with `elementStyleProp` or `elementClassProp`. If any
256
- * styles or classes are set to falsy then they will be removed from the element.
204
+ * This instruction is meant to apply styling via the `[style]="exp"` template bindings.
205
+ * When styles are applied to the element they will then be updated with respect to
206
+ * any styles/classes set via `styleProp`. If any styles are set to falsy
207
+ * then they will be removed from the element.
257
208
  *
258
- * Note that the styling instruction will not be applied until `elementStylingApply` is called.
209
+ * Note that the styling instruction will not be applied until `stylingApply` is called.
259
210
  *
260
- * @param index Index of the element's with which styling is associated.
261
- * @param classes A key/value map or string of CSS classes that will be added to the
262
- * given element. Any missing classes (that have already been applied to the element
263
- * beforehand) will be removed (unset) from the element's list of CSS classes.
264
211
  * @param styles A key/value style map of the styles that will be applied to the given element.
265
212
  * Any missing styles (that have already been applied to the element beforehand) will be
266
213
  * removed (unset) from the element's styling.
267
214
  *
215
+ * Note that this will apply the provided styleMap value to the host element if this function
216
+ * is called within a host binding.
217
+ *
268
218
  * @codeGenApi
269
219
  */
270
- export function ɵɵelementStylingMap(index, classes, styles) {
220
+ export function ɵɵstyleMap(styles) {
221
+ var index = getSelectedIndex();
271
222
  var lView = getLView();
272
223
  var stylingContext = getStylingContext(index, lView);
273
- var tNode = getTNode(index, lView);
274
- // inputs are only evaluated from a template binding into a directive, therefore,
275
- // there should not be a situation where a directive host bindings function
276
- // evaluates the inputs (this should only happen in the template function)
277
- if (hasClassInput(tNode) && classes !== NO_CHANGE) {
278
- var initialClasses = getInitialClassNameValue(stylingContext);
279
- var classInputVal = (initialClasses.length ? (initialClasses + ' ') : '') + forceClassesAsString(classes);
280
- setInputsForProperty(lView, tNode.inputs['class'], classInputVal);
281
- classes = NO_CHANGE;
224
+ var directiveStylingIndex = getActiveDirectiveStylingIndex();
225
+ if (directiveStylingIndex) {
226
+ var args = [stylingContext, styles, directiveStylingIndex];
227
+ enqueueHostInstruction(stylingContext, directiveStylingIndex, updateStyleMap, args);
228
+ }
229
+ else {
230
+ var tNode = getTNode(index, lView);
231
+ // inputs are only evaluated from a template binding into a directive, therefore,
232
+ // there should not be a situation where a directive host bindings function
233
+ // evaluates the inputs (this should only happen in the template function)
234
+ if (hasStyleInput(tNode) && styles !== NO_CHANGE) {
235
+ var initialStyles = getInitialClassNameValue(stylingContext);
236
+ var styleInputVal = (initialStyles.length ? (initialStyles + ' ') : '') + forceStylesAsString(styles);
237
+ setInputsForProperty(lView, tNode.inputs['style'], styleInputVal);
238
+ styles = NO_CHANGE;
239
+ }
240
+ updateStyleMap(stylingContext, styles);
282
241
  }
283
- if (hasStyleInput(tNode) && styles !== NO_CHANGE) {
284
- var initialStyles = getInitialClassNameValue(stylingContext);
285
- var styleInputVal = (initialStyles.length ? (initialStyles + ' ') : '') + forceStylesAsString(styles);
286
- setInputsForProperty(lView, tNode.inputs['style'], styleInputVal);
287
- styles = NO_CHANGE;
242
+ if (runtimeIsNewStylingInUse()) {
243
+ newStyleMap(styles);
288
244
  }
289
- updateStylingMap(stylingContext, classes, styles);
290
245
  }
291
246
  /**
292
- * Update style and/or class host bindings using object literals on an element within the host
293
- * bindings function for a directive/component.
247
+ * Update class bindings using an object literal or class-string on an element.
294
248
  *
295
- * This instruction is meant to apply styling via the `@HostBinding('style')` and
296
- * `@HostBinding('class')` bindings for a component's or directive's host element.
297
- * When styles/classes are applied to the host element they will then be updated
298
- * with respect to any styles/classes set with `elementHostStyleProp` or
299
- * `elementHostClassProp`. If any styles or classes are set to falsy then they
300
- * will be removed from the element.
249
+ * This instruction is meant to apply styling via the `[class]="exp"` template bindings.
250
+ * When classes are applied to the element they will then be updated with
251
+ * respect to any styles/classes set via `classProp`. If any
252
+ * classes are set to falsy then they will be removed from the element.
301
253
  *
302
- * Note that the styling instruction will not be applied until
303
- * `elementHostStylingApply` is called.
254
+ * Note that the styling instruction will not be applied until `stylingApply` is called.
255
+ * Note that this will the provided classMap value to the host element if this function is called
256
+ * within a host binding.
304
257
  *
305
258
  * @param classes A key/value map or string of CSS classes that will be added to the
306
259
  * given element. Any missing classes (that have already been applied to the element
307
260
  * beforehand) will be removed (unset) from the element's list of CSS classes.
308
- * @param styles A key/value style map of the styles that will be applied to the given element.
309
- * Any missing styles (that have already been applied to the element beforehand) will be
310
- * removed (unset) from the element's styling.
311
261
  *
312
262
  * @codeGenApi
313
263
  */
314
- export function ɵɵelementHostStylingMap(classes, styles) {
264
+ export function ɵɵclassMap(classes) {
265
+ var index = getSelectedIndex();
266
+ var lView = getLView();
267
+ var stylingContext = getStylingContext(index, lView);
315
268
  var directiveStylingIndex = getActiveDirectiveStylingIndex();
316
- var hostElementIndex = getSelectedIndex();
317
- var stylingContext = getStylingContext(hostElementIndex, getLView());
318
- var args = [stylingContext, classes, styles, directiveStylingIndex];
319
- enqueueHostInstruction(stylingContext, directiveStylingIndex, updateStylingMap, args);
269
+ if (directiveStylingIndex) {
270
+ var args = [stylingContext, classes, directiveStylingIndex];
271
+ enqueueHostInstruction(stylingContext, directiveStylingIndex, updateClassMap, args);
272
+ }
273
+ else {
274
+ var tNode = getTNode(index, lView);
275
+ // inputs are only evaluated from a template binding into a directive, therefore,
276
+ // there should not be a situation where a directive host bindings function
277
+ // evaluates the inputs (this should only happen in the template function)
278
+ if (hasClassInput(tNode) && classes !== NO_CHANGE) {
279
+ var initialClasses = getInitialClassNameValue(stylingContext);
280
+ var classInputVal = (initialClasses.length ? (initialClasses + ' ') : '') + forceClassesAsString(classes);
281
+ setInputsForProperty(lView, tNode.inputs['class'], classInputVal);
282
+ classes = NO_CHANGE;
283
+ }
284
+ updateClassMap(stylingContext, classes);
285
+ }
286
+ if (runtimeIsNewStylingInUse()) {
287
+ newClassMap(classes);
288
+ }
320
289
  }
321
290
  /**
322
291
  * Apply all style and class binding values to the element.
323
292
  *
324
- * This instruction is meant to be run after `elementStylingMap`, `elementStyleProp`
325
- * or `elementClassProp` instructions have been run and will only apply styling to
326
- * the element if any styling bindings have been updated.
327
- *
328
- * @param index Index of the element's with which styling is associated.
293
+ * This instruction is meant to be run after `styleMap`, `classMap`,
294
+ * `styleProp` or `classProp` instructions have been run and will
295
+ * only apply styling to the element if any styling bindings have been updated.
329
296
  *
330
297
  * @codeGenApi
331
298
  */
332
- export function ɵɵelementStylingApply(index) {
333
- elementStylingApplyInternal(DEFAULT_TEMPLATE_DIRECTIVE_INDEX, index);
334
- }
335
- /**
336
- * Apply all style and class host binding values to the element.
337
- *
338
- * This instruction is meant to be run after `elementHostStylingMap`,
339
- * `elementHostStyleProp` or `elementHostClassProp` instructions have
340
- * been run and will only apply styling to the host element if any
341
- * styling bindings have been updated.
342
- *
343
- * @codeGenApi
344
- */
345
- export function ɵɵelementHostStylingApply() {
346
- elementStylingApplyInternal(getActiveDirectiveStylingIndex(), getSelectedIndex());
347
- }
348
- export function elementStylingApplyInternal(directiveStylingIndex, index) {
299
+ export function ɵɵstylingApply() {
300
+ var index = getSelectedIndex();
301
+ var directiveStylingIndex = getActiveDirectiveStylingIndex() || DEFAULT_TEMPLATE_DIRECTIVE_INDEX;
349
302
  var lView = getLView();
350
303
  var tNode = getTNode(index, lView);
351
304
  // if a non-element value is being processed then we can't render values
@@ -354,10 +307,12 @@ export function elementStylingApplyInternal(directiveStylingIndex, index) {
354
307
  var renderer = tNode.type === 3 /* Element */ ? lView[RENDERER] : null;
355
308
  var isFirstRender = (lView[FLAGS] & 8 /* FirstLViewPass */) !== 0;
356
309
  var stylingContext = getStylingContext(index, lView);
357
- var totalPlayersQueued = renderStyling(stylingContext, renderer, lView, isFirstRender, null, null, directiveStylingIndex);
358
- if (totalPlayersQueued > 0) {
359
- var rootContext = getRootContext(lView);
360
- scheduleTick(rootContext, 2 /* FlushPlayers */);
310
+ if (runtimeAllowOldStyling()) {
311
+ var totalPlayersQueued = renderStyling(stylingContext, renderer, lView, isFirstRender, null, null, directiveStylingIndex);
312
+ if (totalPlayersQueued > 0) {
313
+ var rootContext = getRootContext(lView);
314
+ scheduleTick(rootContext, 2 /* FlushPlayers */);
315
+ }
361
316
  }
362
317
  // because select(n) may not run between every instruction, the cached styling
363
318
  // context may not get cleared between elements. The reason for this is because
@@ -367,6 +322,9 @@ export function elementStylingApplyInternal(directiveStylingIndex, index) {
367
322
  // cleared because there is no code in Angular that applies more styling code after a
368
323
  // styling flush has occurred. Note that this will be fixed once FW-1254 lands.
369
324
  setCachedStylingContext(null);
325
+ if (runtimeIsNewStylingInUse()) {
326
+ newStylingApply();
327
+ }
370
328
  }
371
329
  export function getActiveDirectiveStylingIndex() {
372
330
  // whenever a directive's hostBindings function is called a uniqueId value
@@ -389,4 +347,4 @@ function getStylingContext(index, lView) {
389
347
  }
390
348
  return context;
391
349
  }
392
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"styling.js","sourceRoot":"","sources":["../../../../../../../../../../../packages/core/src/render3/instructions/styling.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 {assertEqual} from '../../util/assert';\nimport {TNode, TNodeType} from '../interfaces/node';\nimport {PlayerFactory} from '../interfaces/player';\nimport {FLAGS, HEADER_OFFSET, LView, LViewFlags, RENDERER, RootContextFlags} from '../interfaces/view';\nimport {getActiveDirectiveId, getActiveDirectiveSuperClassDepth, getLView, getPreviousOrParentTNode, getSelectedIndex} from '../state';\nimport {getInitialClassNameValue, renderStyling, updateClassProp as updateElementClassProp, updateContextWithBindings, updateStyleProp as updateElementStyleProp, updateStylingMap} from '../styling/class_and_style_bindings';\nimport {ParamsOf, enqueueHostInstruction, registerHostDirective} from '../styling/host_instructions_queue';\nimport {BoundPlayerFactory} from '../styling/player_factory';\nimport {DEFAULT_TEMPLATE_DIRECTIVE_INDEX} from '../styling/shared';\nimport {getCachedStylingContext, setCachedStylingContext} from '../styling/state';\nimport {allocateOrUpdateDirectiveIntoContext, createEmptyStylingContext, forceClassesAsString, forceStylesAsString, getStylingContextFromLView, hasClassInput, hasStyleInput} from '../styling/util';\nimport {NO_CHANGE} from '../tokens';\nimport {renderStringify} from '../util/misc_utils';\nimport {getRootContext} from '../util/view_traversal_utils';\nimport {getTNode} from '../util/view_utils';\n\nimport {scheduleTick, setInputsForProperty} from './shared';\n\n\n\n/*\n * The contents of this file include the instructions for all styling-related\n * operations in Angular.\n *\n * The instructions present in this file are:\n *\n * Template level styling instructions:\n * - elementStyling\n * - elementStylingMap\n * - elementStyleProp\n * - elementClassProp\n * - elementStylingApply\n *\n * Host bindings level styling instructions:\n * - elementHostStyling\n * - elementHostStylingMap\n * - elementHostStyleProp\n * - elementHostClassProp\n * - elementHostStylingApply\n */\n\n/**\n * Allocates style and class binding properties on the element during creation mode.\n *\n * This instruction is meant to be called during creation mode to register all\n * dynamic style and class bindings on the element. Note that this is only used\n * for binding values (see `elementStart` to learn how to assign static styling\n * values to an element).\n *\n * @param classBindingNames An array containing bindable class names.\n *        The `elementClassProp` instruction refers to the class name by index in\n *        this array (i.e. `['foo', 'bar']` means `foo=0` and `bar=1`).\n * @param styleBindingNames An array containing bindable style properties.\n *        The `elementStyleProp` instruction refers to the class name by index in\n *        this array (i.e. `['width', 'height']` means `width=0` and `height=1`).\n * @param styleSanitizer An optional sanitizer function that will be used to sanitize any CSS\n *        style values that are applied to the element (during rendering).\n *\n * @codeGenApi\n */\nexport function ɵɵelementStyling(\n    classBindingNames?: string[] | null, styleBindingNames?: string[] | null,\n    styleSanitizer?: StyleSanitizeFn | null): void {\n  const tNode = getPreviousOrParentTNode();\n  if (!tNode.stylingTemplate) {\n    tNode.stylingTemplate = createEmptyStylingContext();\n  }\n\n  // calling the function below ensures that the template's binding values\n  // are applied as the first set of bindings into the context. If any other\n  // styling bindings are set on the same element (by directives and/or\n  // components) then they will be applied at the end of the `elementEnd`\n  // instruction (because directives are created first before styling is\n  // executed for a new element).\n  initElementStyling(\n      tNode, classBindingNames, styleBindingNames, styleSanitizer,\n      DEFAULT_TEMPLATE_DIRECTIVE_INDEX);\n}\n\n/**\n * Allocates style and class binding properties on the host element during creation mode\n * within the host bindings function of a directive or component.\n *\n * This instruction is meant to be called during creation mode to register all\n * dynamic style and class host bindings on the host element of a directive or\n * component. Note that this is only used for binding values (see `elementHostAttrs`\n * to learn how to assign static styling values to the host element).\n *\n * @param classBindingNames An array containing bindable class names.\n *        The `elementHostClassProp` instruction refers to the class name by index in\n *        this array (i.e. `['foo', 'bar']` means `foo=0` and `bar=1`).\n * @param styleBindingNames An array containing bindable style properties.\n *        The `elementHostStyleProp` instruction refers to the class name by index in\n *        this array (i.e. `['width', 'height']` means `width=0` and `height=1`).\n * @param styleSanitizer An optional sanitizer function that will be used to sanitize any CSS\n *        style values that are applied to the element (during rendering).\n *        Note that the sanitizer instance itself is tied to the provided `directive` and\n *        will not be used if the same property is assigned in another directive or\n *        on the element directly.\n *\n * @codeGenApi\n */\nexport function ɵɵelementHostStyling(\n    classBindingNames?: string[] | null, styleBindingNames?: string[] | null,\n    styleSanitizer?: StyleSanitizeFn | null): void {\n  const tNode = getPreviousOrParentTNode();\n  if (!tNode.stylingTemplate) {\n    tNode.stylingTemplate = createEmptyStylingContext();\n  }\n\n  const directiveStylingIndex = getActiveDirectiveStylingIndex();\n\n  // despite the binding being applied in a queue (below), the allocation\n  // of the directive into the context happens right away. The reason for\n  // this is to retain the ordering of the directives (which is important\n  // for the prioritization of bindings).\n  allocateOrUpdateDirectiveIntoContext(tNode.stylingTemplate, directiveStylingIndex);\n\n  const fns = tNode.onElementCreationFns = tNode.onElementCreationFns || [];\n  fns.push(() => {\n    initElementStyling(\n        tNode, classBindingNames, styleBindingNames, styleSanitizer, directiveStylingIndex);\n    registerHostDirective(tNode.stylingTemplate !, directiveStylingIndex);\n  });\n}\n\nfunction initElementStyling(\n    tNode: TNode, classBindingNames: string[] | null | undefined,\n    styleBindingNames: string[] | null | undefined,\n    styleSanitizer: StyleSanitizeFn | null | undefined, directiveStylingIndex: number): void {\n  updateContextWithBindings(\n      tNode.stylingTemplate !, directiveStylingIndex, classBindingNames, styleBindingNames,\n      styleSanitizer);\n}\n\n\n/**\n * Update a style binding on an element with the provided value.\n *\n * If the style value is falsy then it will be removed from the element\n * (or assigned a different value depending if there are any styles placed\n * on the element with `elementStylingMap` or any static styles that are\n * present from when the element was created with `elementStyling`).\n *\n * Note that the styling element is updated as part of `elementStylingApply`.\n *\n * @param index Index of the element's with which styling is associated.\n * @param styleIndex Index of style to update. This index value refers to the\n *        index of the style in the style bindings array that was passed into\n *        `elementStyling`.\n * @param value New value to write (falsy to remove). Note that if a directive also\n *        attempts to write to the same binding value (via `elementHostStyleProp`)\n *        then it will only be able to do so if the binding value assigned via\n *        `elementStyleProp` is falsy (or doesn't exist at all).\n * @param suffix Optional suffix. Used with scalar values to add unit such as `px`.\n *        Note that when a suffix is provided then the underlying sanitizer will\n *        be ignored.\n * @param forceOverride Whether or not to update the styling value immediately\n *        (despite the other bindings possibly having priority)\n *\n * @codeGenApi\n */\nexport function ɵɵelementStyleProp(\n    index: number, styleIndex: number, value: string | number | String | PlayerFactory | null,\n    suffix?: string | null, forceOverride?: boolean): void {\n  const valueToAdd = resolveStylePropValue(value, suffix);\n  const stylingContext = getStylingContext(index, getLView());\n  updateElementStyleProp(\n      stylingContext, styleIndex, valueToAdd, DEFAULT_TEMPLATE_DIRECTIVE_INDEX, forceOverride);\n}\n\n/**\n * Update a host style binding value on the host element within a component/directive.\n *\n * If the style value is falsy then it will be removed from the host element\n * (or assigned a different value depending if there are any styles placed\n * on the same element with `elementHostStylingMap` or any static styles that\n * are present from when the element was patched with `elementHostStyling`).\n *\n * Note that the styling applied to the host element once\n * `elementHostStylingApply` is called.\n *\n * @param styleIndex Index of style to update. This index value refers to the\n *        index of the style in the style bindings array that was passed into\n *        `elementHostStyling`.\n * @param value New value to write (falsy to remove). The value may or may not\n *        be applied to the element depending on the template/component/directive\n *        prioritization (see `interfaces/styling.ts`)\n * @param suffix Optional suffix. Used with scalar values to add unit such as `px`.\n *        Note that when a suffix is provided then the underlying sanitizer will\n *        be ignored.\n * @param forceOverride Whether or not to update the styling value immediately\n *        (despite the other bindings possibly having priority)\n *\n * @codeGenApi\n */\nexport function ɵɵelementHostStyleProp(\n    styleIndex: number, value: string | number | String | PlayerFactory | null,\n    suffix?: string | null, forceOverride?: boolean): void {\n  const directiveStylingIndex = getActiveDirectiveStylingIndex();\n  const hostElementIndex = getSelectedIndex();\n\n  const stylingContext = getStylingContext(hostElementIndex, getLView());\n  const valueToAdd = resolveStylePropValue(value, suffix);\n  const args: ParamsOf<typeof updateElementStyleProp> =\n      [stylingContext, styleIndex, valueToAdd, directiveStylingIndex, forceOverride];\n  enqueueHostInstruction(stylingContext, directiveStylingIndex, updateElementStyleProp, args);\n}\n\nfunction resolveStylePropValue(\n    value: string | number | String | PlayerFactory | null, suffix: string | null | undefined) {\n  let valueToAdd: string|null = null;\n  if (value !== null) {\n    if (suffix) {\n      // when a suffix is applied then it will bypass\n      // sanitization entirely (b/c a new string is created)\n      valueToAdd = renderStringify(value) + suffix;\n    } else {\n      // sanitization happens by dealing with a String value\n      // this means that the string value will be passed through\n      // into the style rendering later (which is where the value\n      // will be sanitized before it is applied)\n      valueToAdd = value as any as string;\n    }\n  }\n  return valueToAdd;\n}\n\n\n/**\n * Update a class binding on an element with the provided value.\n *\n * This instruction is meant to handle the `[class.foo]=\"exp\"` case and,\n * therefore, the class binding itself must already be allocated using\n * `elementStyling` within the creation block.\n *\n * @param index Index of the element's with which styling is associated.\n * @param classIndex Index of class to toggle. This index value refers to the\n *        index of the class in the class bindings array that was passed into\n *        `elementStyling` (which is meant to be called before this\n *        function is).\n * @param value A true/false value which will turn the class on or off.\n * @param forceOverride Whether or not this value will be applied regardless\n *        of where it is being set within the styling priority structure.\n *\n * @codeGenApi\n */\nexport function ɵɵelementClassProp(\n    index: number, classIndex: number, value: boolean | PlayerFactory,\n    forceOverride?: boolean): void {\n  const input = (value instanceof BoundPlayerFactory) ?\n      (value as BoundPlayerFactory<boolean|null>) :\n      booleanOrNull(value);\n  const stylingContext = getStylingContext(index, getLView());\n  updateElementClassProp(\n      stylingContext, classIndex, input, DEFAULT_TEMPLATE_DIRECTIVE_INDEX, forceOverride);\n}\n\n\n/**\n * Update a class host binding for a directive's/component's host element within\n * the host bindings function.\n *\n * This instruction is meant to handle the `@HostBinding('class.foo')` case and,\n * therefore, the class binding itself must already be allocated using\n * `elementHostStyling` within the creation block.\n *\n * @param classIndex Index of class to toggle. This index value refers to the\n *        index of the class in the class bindings array that was passed into\n *        `elementHostStlying` (which is meant to be called before this\n *        function is).\n * @param value A true/false value which will turn the class on or off.\n * @param forceOverride Whether or not this value will be applied regardless\n *        of where it is being set within the stylings priority structure.\n *\n * @codeGenApi\n */\nexport function ɵɵelementHostClassProp(\n    classIndex: number, value: boolean | PlayerFactory, forceOverride?: boolean): void {\n  const directiveStylingIndex = getActiveDirectiveStylingIndex();\n  const hostElementIndex = getSelectedIndex();\n  const stylingContext = getStylingContext(hostElementIndex, getLView());\n\n  const input = (value instanceof BoundPlayerFactory) ?\n      (value as BoundPlayerFactory<boolean|null>) :\n      booleanOrNull(value);\n\n  const args: ParamsOf<typeof updateElementClassProp> =\n      [stylingContext, classIndex, input, directiveStylingIndex, forceOverride];\n  enqueueHostInstruction(stylingContext, directiveStylingIndex, updateElementClassProp, args);\n}\n\nfunction booleanOrNull(value: any): boolean|null {\n  if (typeof value === 'boolean') return value;\n  return value ? true : null;\n}\n\n\n/**\n * Update style and/or class bindings using object literals on an element.\n *\n * This instruction is meant to apply styling via the `[style]=\"exp\"` and `[class]=\"exp\"` template\n * bindings. When styles/classes are applied to the element they will then be updated with\n * respect to any styles/classes set with `elementStyleProp` or `elementClassProp`. If any\n * styles or classes are set to falsy then they will be removed from the element.\n *\n * Note that the styling instruction will not be applied until `elementStylingApply` is called.\n *\n * @param index Index of the element's with which styling is associated.\n * @param classes A key/value map or string of CSS classes that will be added to the\n *        given element. Any missing classes (that have already been applied to the element\n *        beforehand) will be removed (unset) from the element's list of CSS classes.\n * @param styles A key/value style map of the styles that will be applied to the given element.\n *        Any missing styles (that have already been applied to the element beforehand) will be\n *        removed (unset) from the element's styling.\n *\n * @codeGenApi\n */\nexport function ɵɵelementStylingMap(\n    index: number, classes: {[key: string]: any} | string | NO_CHANGE | null,\n    styles?: {[styleName: string]: any} | NO_CHANGE | null): void {\n  const lView = getLView();\n  const stylingContext = getStylingContext(index, lView);\n  const tNode = getTNode(index, lView);\n\n  // inputs are only evaluated from a template binding into a directive, therefore,\n  // there should not be a situation where a directive host bindings function\n  // evaluates the inputs (this should only happen in the template function)\n  if (hasClassInput(tNode) && classes !== NO_CHANGE) {\n    const initialClasses = getInitialClassNameValue(stylingContext);\n    const classInputVal =\n        (initialClasses.length ? (initialClasses + ' ') : '') + forceClassesAsString(classes);\n    setInputsForProperty(lView, tNode.inputs !['class'] !, classInputVal);\n    classes = NO_CHANGE;\n  }\n\n  if (hasStyleInput(tNode) && styles !== NO_CHANGE) {\n    const initialStyles = getInitialClassNameValue(stylingContext);\n    const styleInputVal =\n        (initialStyles.length ? (initialStyles + ' ') : '') + forceStylesAsString(styles);\n    setInputsForProperty(lView, tNode.inputs !['style'] !, styleInputVal);\n    styles = NO_CHANGE;\n  }\n\n  updateStylingMap(stylingContext, classes, styles);\n}\n\n\n/**\n * Update style and/or class host bindings using object literals on an element within the host\n * bindings function for a directive/component.\n *\n * This instruction is meant to apply styling via the `@HostBinding('style')` and\n * `@HostBinding('class')` bindings for a component's or directive's host element.\n * When styles/classes are applied to the host element they will then be updated\n * with respect to any styles/classes set with `elementHostStyleProp` or\n * `elementHostClassProp`. If any styles or classes are set to falsy then they\n * will be removed from the element.\n *\n * Note that the styling instruction will not be applied until\n * `elementHostStylingApply` is called.\n *\n * @param classes A key/value map or string of CSS classes that will be added to the\n *        given element. Any missing classes (that have already been applied to the element\n *        beforehand) will be removed (unset) from the element's list of CSS classes.\n * @param styles A key/value style map of the styles that will be applied to the given element.\n *        Any missing styles (that have already been applied to the element beforehand) will be\n *        removed (unset) from the element's styling.\n *\n * @codeGenApi\n */\nexport function ɵɵelementHostStylingMap(\n    classes: {[key: string]: any} | string | NO_CHANGE | null,\n    styles?: {[styleName: string]: any} | NO_CHANGE | null): void {\n  const directiveStylingIndex = getActiveDirectiveStylingIndex();\n  const hostElementIndex = getSelectedIndex();\n  const stylingContext = getStylingContext(hostElementIndex, getLView());\n  const args: ParamsOf<typeof updateStylingMap> =\n      [stylingContext, classes, styles, directiveStylingIndex];\n  enqueueHostInstruction(stylingContext, directiveStylingIndex, updateStylingMap, args);\n}\n\n\n/**\n * Apply all style and class binding values to the element.\n *\n * This instruction is meant to be run after `elementStylingMap`, `elementStyleProp`\n * or `elementClassProp` instructions have been run and will only apply styling to\n * the element if any styling bindings have been updated.\n *\n * @param index Index of the element's with which styling is associated.\n *\n * @codeGenApi\n */\nexport function ɵɵelementStylingApply(index: number): void {\n  elementStylingApplyInternal(DEFAULT_TEMPLATE_DIRECTIVE_INDEX, index);\n}\n\n/**\n * Apply all style and class host binding values to the element.\n *\n * This instruction is meant to be run after `elementHostStylingMap`,\n * `elementHostStyleProp` or `elementHostClassProp` instructions have\n * been run and will only apply styling to the host element if any\n * styling bindings have been updated.\n *\n * @codeGenApi\n */\nexport function ɵɵelementHostStylingApply(): void {\n  elementStylingApplyInternal(getActiveDirectiveStylingIndex(), getSelectedIndex());\n}\n\nexport function elementStylingApplyInternal(directiveStylingIndex: number, index: number): void {\n  const lView = getLView();\n  const tNode = getTNode(index, lView);\n\n  // if a non-element value is being processed then we can't render values\n  // on the element at all therefore by setting the renderer to null then\n  // the styling apply code knows not to actually apply the values...\n  const renderer = tNode.type === TNodeType.Element ? lView[RENDERER] : null;\n  const isFirstRender = (lView[FLAGS] & LViewFlags.FirstLViewPass) !== 0;\n  const stylingContext = getStylingContext(index, lView);\n  const totalPlayersQueued = renderStyling(\n      stylingContext, renderer, lView, isFirstRender, null, null, directiveStylingIndex);\n  if (totalPlayersQueued > 0) {\n    const rootContext = getRootContext(lView);\n    scheduleTick(rootContext, RootContextFlags.FlushPlayers);\n  }\n\n  // because select(n) may not run between every instruction, the cached styling\n  // context may not get cleared between elements. The reason for this is because\n  // styling bindings (like `[style]` and `[class]`) are not recognized as property\n  // bindings by default so a select(n) instruction is not generated. To ensure the\n  // context is loaded correctly for the next element the cache below is pre-emptively\n  // cleared because there is no code in Angular that applies more styling code after a\n  // styling flush has occurred. Note that this will be fixed once FW-1254 lands.\n  setCachedStylingContext(null);\n}\n\nexport function getActiveDirectiveStylingIndex() {\n  // whenever a directive's hostBindings function is called a uniqueId value\n  // is assigned. Normally this is enough to help distinguish one directive\n  // from another for the styling context, but there are situations where a\n  // sub-class directive could inherit and assign styling in concert with a\n  // parent directive. To help the styling code distinguish between a parent\n  // sub-classed directive the inheritance depth is taken into account as well.\n  return getActiveDirectiveId() + getActiveDirectiveSuperClassDepth();\n}\n\nfunction getStylingContext(index: number, lView: LView) {\n  let context = getCachedStylingContext();\n  if (!context) {\n    context = getStylingContextFromLView(index + HEADER_OFFSET, lView);\n    setCachedStylingContext(context);\n  } else if (ngDevMode) {\n    const actualContext = getStylingContextFromLView(index + HEADER_OFFSET, lView);\n    assertEqual(context, actualContext, 'The cached styling context is invalid');\n  }\n  return context;\n}\n"]}
350
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"styling.js","sourceRoot":"","sources":["../../../../../../../../../../../packages/core/src/render3/instructions/styling.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 {assertEqual} from '../../util/assert';\nimport {TNode, TNodeType} from '../interfaces/node';\nimport {PlayerFactory} from '../interfaces/player';\nimport {FLAGS, HEADER_OFFSET, LView, LViewFlags, RENDERER, RootContextFlags} from '../interfaces/view';\nimport {getActiveDirectiveId, getActiveDirectiveSuperClassDepth, getLView, getPreviousOrParentTNode, getSelectedIndex} from '../state';\nimport {getInitialClassNameValue, renderStyling, updateClassMap, updateClassProp as updateclassProp, updateContextWithBindings, updateStyleMap, updateStyleProp as updatestyleProp} from '../styling/class_and_style_bindings';\nimport {ParamsOf, enqueueHostInstruction, registerHostDirective} from '../styling/host_instructions_queue';\nimport {BoundPlayerFactory} from '../styling/player_factory';\nimport {DEFAULT_TEMPLATE_DIRECTIVE_INDEX} from '../styling/shared';\nimport {getCachedStylingContext, setCachedStylingContext} from '../styling/state';\nimport {allocateOrUpdateDirectiveIntoContext, createEmptyStylingContext, forceClassesAsString, forceStylesAsString, getStylingContextFromLView, hasClassInput, hasStyleInput} from '../styling/util';\nimport {classMap as newClassMap, classProp as newClassProp, styleMap as newStyleMap, styleProp as newStyleProp, stylingApply as newStylingApply, stylingInit as newStylingInit} from '../styling_next/instructions';\nimport {runtimeAllowOldStyling, runtimeIsNewStylingInUse} from '../styling_next/state';\nimport {getBindingNameFromIndex} from '../styling_next/util';\nimport {NO_CHANGE} from '../tokens';\nimport {renderStringify} from '../util/misc_utils';\nimport {getRootContext} from '../util/view_traversal_utils';\nimport {getTNode} from '../util/view_utils';\n\nimport {scheduleTick, setInputsForProperty} from './shared';\n\n\n\n/*\n * The contents of this file include the instructions for all styling-related\n * operations in Angular.\n *\n * The instructions present in this file are:\n *\n * Template level styling instructions:\n * - styling\n * - styleMap\n * - classMap\n * - styleProp\n * - classProp\n * - stylingApply\n */\n\n/**\n * Allocates style and class binding properties on the element during creation mode.\n *\n * This instruction is meant to be called during creation mode to register all\n * dynamic style and class bindings on the element. Note that this is only used\n * for binding values (see `elementStart` to learn how to assign static styling\n * values to an element).\n *\n * @param classBindingNames An array containing bindable class names.\n *        The `classProp` instruction refers to the class name by index in\n *        this array (i.e. `['foo', 'bar']` means `foo=0` and `bar=1`).\n * @param styleBindingNames An array containing bindable style properties.\n *        The `styleProp` instruction refers to the class name by index in\n *        this array (i.e. `['width', 'height']` means `width=0` and `height=1`).\n * @param styleSanitizer An optional sanitizer function that will be used to sanitize any CSS\n *        style values that are applied to the element (during rendering).\n *\n * Note that this will allocate the provided style/class bindings to the host element if\n * this function is called within a host binding.\n *\n * @codeGenApi\n */\nexport function ɵɵstyling(\n    classBindingNames?: string[] | null, styleBindingNames?: string[] | null,\n    styleSanitizer?: StyleSanitizeFn | null): void {\n  const tNode = getPreviousOrParentTNode();\n  if (!tNode.stylingTemplate) {\n    tNode.stylingTemplate = createEmptyStylingContext();\n  }\n\n  const directiveStylingIndex = getActiveDirectiveStylingIndex();\n  if (directiveStylingIndex) {\n    // this is temporary hack to get the existing styling instructions to\n    // play ball with the new refactored implementation.\n    // TODO (matsko): remove this once the old implementation is not needed.\n    if (runtimeIsNewStylingInUse()) {\n      newStylingInit();\n    }\n\n    // despite the binding being applied in a queue (below), the allocation\n    // of the directive into the context happens right away. The reason for\n    // this is to retain the ordering of the directives (which is important\n    // for the prioritization of bindings).\n    allocateOrUpdateDirectiveIntoContext(tNode.stylingTemplate, directiveStylingIndex);\n\n    const fns = tNode.onElementCreationFns = tNode.onElementCreationFns || [];\n    fns.push(() => {\n      initStyling(\n          tNode, classBindingNames, styleBindingNames, styleSanitizer, directiveStylingIndex);\n      registerHostDirective(tNode.stylingTemplate !, directiveStylingIndex);\n    });\n  } else {\n    // calling the function below ensures that the template's binding values\n    // are applied as the first set of bindings into the context. If any other\n    // styling bindings are set on the same element (by directives and/or\n    // components) then they will be applied at the end of the `elementEnd`\n    // instruction (because directives are created first before styling is\n    // executed for a new element).\n    initStyling(\n        tNode, classBindingNames, styleBindingNames, styleSanitizer,\n        DEFAULT_TEMPLATE_DIRECTIVE_INDEX);\n  }\n}\n\nfunction initStyling(\n    tNode: TNode, classBindingNames: string[] | null | undefined,\n    styleBindingNames: string[] | null | undefined,\n    styleSanitizer: StyleSanitizeFn | null | undefined, directiveStylingIndex: number): void {\n  updateContextWithBindings(\n      tNode.stylingTemplate !, directiveStylingIndex, classBindingNames, styleBindingNames,\n      styleSanitizer);\n}\n\n\n/**\n * Update a style binding on an element with the provided value.\n *\n * If the style value is falsy then it will be removed from the element\n * (or assigned a different value depending if there are any styles placed\n * on the element with `styleMap` or any static styles that are\n * present from when the element was created with `styling`).\n *\n * Note that the styling element is updated as part of `stylingApply`.\n *\n * @param styleIndex Index of style to update. This index value refers to the\n *        index of the style in the style bindings array that was passed into\n *        `styling`.\n * @param value New value to write (falsy to remove).\n * @param suffix Optional suffix. Used with scalar values to add unit such as `px`.\n *        Note that when a suffix is provided then the underlying sanitizer will\n *        be ignored.\n * @param forceOverride Whether or not to update the styling value immediately\n *        (despite the other bindings possibly having priority)\n *\n * Note that this will apply the provided style value to the host element if this function is called\n * within a host binding.\n *\n * @codeGenApi\n */\nexport function ɵɵstyleProp(\n    styleIndex: number, value: string | number | String | PlayerFactory | null,\n    suffix?: string | null, forceOverride?: boolean): void {\n  const index = getSelectedIndex();\n  const valueToAdd = resolveStylePropValue(value, suffix);\n  const stylingContext = getStylingContext(index, getLView());\n  const directiveStylingIndex = getActiveDirectiveStylingIndex();\n  if (directiveStylingIndex) {\n    const args: ParamsOf<typeof updatestyleProp> =\n        [stylingContext, styleIndex, valueToAdd, directiveStylingIndex, forceOverride];\n    enqueueHostInstruction(stylingContext, directiveStylingIndex, updatestyleProp, args);\n  } else {\n    updatestyleProp(\n        stylingContext, styleIndex, valueToAdd, DEFAULT_TEMPLATE_DIRECTIVE_INDEX, forceOverride);\n  }\n\n  if (runtimeIsNewStylingInUse()) {\n    const prop = getBindingNameFromIndex(stylingContext, styleIndex, directiveStylingIndex, false);\n\n    // the reason why we cast the value as `boolean` is\n    // because the new styling refactor does not yet support\n    // sanitization or animation players.\n    newStyleProp(prop, value as string | number, suffix);\n  }\n}\n\nfunction resolveStylePropValue(\n    value: string | number | String | PlayerFactory | null, suffix: string | null | undefined) {\n  let valueToAdd: string|null = null;\n  if (value !== null) {\n    if (suffix) {\n      // when a suffix is applied then it will bypass\n      // sanitization entirely (b/c a new string is created)\n      valueToAdd = renderStringify(value) + suffix;\n    } else {\n      // sanitization happens by dealing with a String value\n      // this means that the string value will be passed through\n      // into the style rendering later (which is where the value\n      // will be sanitized before it is applied)\n      valueToAdd = value as any as string;\n    }\n  }\n  return valueToAdd;\n}\n\n\n/**\n * Update a class binding on an element with the provided value.\n *\n * This instruction is meant to handle the `[class.foo]=\"exp\"` case and,\n * therefore, the class binding itself must already be allocated using\n * `styling` within the creation block.\n *\n * @param classIndex Index of class to toggle. This index value refers to the\n *        index of the class in the class bindings array that was passed into\n *        `styling` (which is meant to be called before this\n *        function is).\n * @param value A true/false value which will turn the class on or off.\n * @param forceOverride Whether or not this value will be applied regardless\n *        of where it is being set within the styling priority structure.\n *\n * Note that this will apply the provided class value to the host element if this function\n * is called within a host binding.\n *\n * @codeGenApi\n */\nexport function ɵɵclassProp(\n    classIndex: number, value: boolean | PlayerFactory, forceOverride?: boolean): void {\n  const index = getSelectedIndex();\n  const input = (value instanceof BoundPlayerFactory) ?\n      (value as BoundPlayerFactory<boolean|null>) :\n      booleanOrNull(value);\n  const directiveStylingIndex = getActiveDirectiveStylingIndex();\n  const stylingContext = getStylingContext(index, getLView());\n  if (directiveStylingIndex) {\n    const args: ParamsOf<typeof updateclassProp> =\n        [stylingContext, classIndex, input, directiveStylingIndex, forceOverride];\n    enqueueHostInstruction(stylingContext, directiveStylingIndex, updateclassProp, args);\n  } else {\n    updateclassProp(\n        stylingContext, classIndex, input, DEFAULT_TEMPLATE_DIRECTIVE_INDEX, forceOverride);\n  }\n\n  if (runtimeIsNewStylingInUse()) {\n    const prop = getBindingNameFromIndex(stylingContext, classIndex, directiveStylingIndex, true);\n\n    // the reason why we cast the value as `boolean` is\n    // because the new styling refactor does not yet support\n    // sanitization or animation players.\n    newClassProp(prop, input as boolean);\n  }\n}\n\n\nfunction booleanOrNull(value: any): boolean|null {\n  if (typeof value === 'boolean') return value;\n  return value ? true : null;\n}\n\n\n/**\n * Update style bindings using an object literal on an element.\n *\n * This instruction is meant to apply styling via the `[style]=\"exp\"` template bindings.\n * When styles are applied to the element they will then be updated with respect to\n * any styles/classes set via `styleProp`. If any styles are set to falsy\n * then they will be removed from the element.\n *\n * Note that the styling instruction will not be applied until `stylingApply` is called.\n *\n * @param styles A key/value style map of the styles that will be applied to the given element.\n *        Any missing styles (that have already been applied to the element beforehand) will be\n *        removed (unset) from the element's styling.\n *\n * Note that this will apply the provided styleMap value to the host element if this function\n * is called within a host binding.\n *\n * @codeGenApi\n */\nexport function ɵɵstyleMap(styles: {[styleName: string]: any} | NO_CHANGE | null): void {\n  const index = getSelectedIndex();\n  const lView = getLView();\n  const stylingContext = getStylingContext(index, lView);\n  const directiveStylingIndex = getActiveDirectiveStylingIndex();\n  if (directiveStylingIndex) {\n    const args: ParamsOf<typeof updateStyleMap> = [stylingContext, styles, directiveStylingIndex];\n    enqueueHostInstruction(stylingContext, directiveStylingIndex, updateStyleMap, args);\n  } else {\n    const tNode = getTNode(index, lView);\n\n    // inputs are only evaluated from a template binding into a directive, therefore,\n    // there should not be a situation where a directive host bindings function\n    // evaluates the inputs (this should only happen in the template function)\n    if (hasStyleInput(tNode) && styles !== NO_CHANGE) {\n      const initialStyles = getInitialClassNameValue(stylingContext);\n      const styleInputVal =\n          (initialStyles.length ? (initialStyles + ' ') : '') + forceStylesAsString(styles);\n      setInputsForProperty(lView, tNode.inputs !['style'] !, styleInputVal);\n      styles = NO_CHANGE;\n    }\n    updateStyleMap(stylingContext, styles);\n  }\n\n  if (runtimeIsNewStylingInUse()) {\n    newStyleMap(styles);\n  }\n}\n\n\n/**\n * Update class bindings using an object literal or class-string on an element.\n *\n * This instruction is meant to apply styling via the `[class]=\"exp\"` template bindings.\n * When classes are applied to the element they will then be updated with\n * respect to any styles/classes set via `classProp`. If any\n * classes are set to falsy then they will be removed from the element.\n *\n * Note that the styling instruction will not be applied until `stylingApply` is called.\n * Note that this will the provided classMap value to the host element if this function is called\n * within a host binding.\n *\n * @param classes A key/value map or string of CSS classes that will be added to the\n *        given element. Any missing classes (that have already been applied to the element\n *        beforehand) will be removed (unset) from the element's list of CSS classes.\n *\n * @codeGenApi\n */\nexport function ɵɵclassMap(classes: {[styleName: string]: any} | NO_CHANGE | string | null): void {\n  const index = getSelectedIndex();\n  const lView = getLView();\n  const stylingContext = getStylingContext(index, lView);\n  const directiveStylingIndex = getActiveDirectiveStylingIndex();\n  if (directiveStylingIndex) {\n    const args: ParamsOf<typeof updateClassMap> = [stylingContext, classes, directiveStylingIndex];\n    enqueueHostInstruction(stylingContext, directiveStylingIndex, updateClassMap, args);\n  } else {\n    const tNode = getTNode(index, lView);\n    // inputs are only evaluated from a template binding into a directive, therefore,\n    // there should not be a situation where a directive host bindings function\n    // evaluates the inputs (this should only happen in the template function)\n    if (hasClassInput(tNode) && classes !== NO_CHANGE) {\n      const initialClasses = getInitialClassNameValue(stylingContext);\n      const classInputVal =\n          (initialClasses.length ? (initialClasses + ' ') : '') + forceClassesAsString(classes);\n      setInputsForProperty(lView, tNode.inputs !['class'] !, classInputVal);\n      classes = NO_CHANGE;\n    }\n    updateClassMap(stylingContext, classes);\n  }\n\n  if (runtimeIsNewStylingInUse()) {\n    newClassMap(classes);\n  }\n}\n\n/**\n * Apply all style and class binding values to the element.\n *\n * This instruction is meant to be run after `styleMap`, `classMap`,\n * `styleProp` or `classProp` instructions have been run and will\n * only apply styling to the element if any styling bindings have been updated.\n *\n * @codeGenApi\n */\nexport function ɵɵstylingApply(): void {\n  const index = getSelectedIndex();\n  const directiveStylingIndex =\n      getActiveDirectiveStylingIndex() || DEFAULT_TEMPLATE_DIRECTIVE_INDEX;\n  const lView = getLView();\n  const tNode = getTNode(index, lView);\n\n  // if a non-element value is being processed then we can't render values\n  // on the element at all therefore by setting the renderer to null then\n  // the styling apply code knows not to actually apply the values...\n  const renderer = tNode.type === TNodeType.Element ? lView[RENDERER] : null;\n  const isFirstRender = (lView[FLAGS] & LViewFlags.FirstLViewPass) !== 0;\n  const stylingContext = getStylingContext(index, lView);\n\n  if (runtimeAllowOldStyling()) {\n    const totalPlayersQueued = renderStyling(\n        stylingContext, renderer, lView, isFirstRender, null, null, directiveStylingIndex);\n    if (totalPlayersQueued > 0) {\n      const rootContext = getRootContext(lView);\n      scheduleTick(rootContext, RootContextFlags.FlushPlayers);\n    }\n  }\n\n  // because select(n) may not run between every instruction, the cached styling\n  // context may not get cleared between elements. The reason for this is because\n  // styling bindings (like `[style]` and `[class]`) are not recognized as property\n  // bindings by default so a select(n) instruction is not generated. To ensure the\n  // context is loaded correctly for the next element the cache below is pre-emptively\n  // cleared because there is no code in Angular that applies more styling code after a\n  // styling flush has occurred. Note that this will be fixed once FW-1254 lands.\n  setCachedStylingContext(null);\n\n  if (runtimeIsNewStylingInUse()) {\n    newStylingApply();\n  }\n}\n\nexport function getActiveDirectiveStylingIndex() {\n  // whenever a directive's hostBindings function is called a uniqueId value\n  // is assigned. Normally this is enough to help distinguish one directive\n  // from another for the styling context, but there are situations where a\n  // sub-class directive could inherit and assign styling in concert with a\n  // parent directive. To help the styling code distinguish between a parent\n  // sub-classed directive the inheritance depth is taken into account as well.\n  return getActiveDirectiveId() + getActiveDirectiveSuperClassDepth();\n}\n\nfunction getStylingContext(index: number, lView: LView) {\n  let context = getCachedStylingContext();\n  if (!context) {\n    context = getStylingContextFromLView(index + HEADER_OFFSET, lView);\n    setCachedStylingContext(context);\n  } else if (ngDevMode) {\n    const actualContext = getStylingContextFromLView(index + HEADER_OFFSET, lView);\n    assertEqual(context, actualContext, 'The cached styling context is invalid');\n  }\n  return context;\n}\n"]}