@angular/core 9.0.0-rc.7 → 9.0.1

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 (222) hide show
  1. package/bundles/core-testing.umd.js +18 -16
  2. package/bundles/core-testing.umd.js.map +1 -1
  3. package/bundles/core-testing.umd.min.js +7 -7
  4. package/bundles/core-testing.umd.min.js.map +1 -1
  5. package/bundles/core.umd.js +6386 -6384
  6. package/bundles/core.umd.js.map +1 -1
  7. package/bundles/core.umd.min.js +182 -175
  8. package/bundles/core.umd.min.js.map +1 -1
  9. package/core.d.ts +726 -734
  10. package/core.metadata.json +1 -1
  11. package/esm2015/core.externs.js +5 -5
  12. package/esm2015/core.js +17 -15
  13. package/esm2015/index.js +2 -2
  14. package/esm2015/public_api.js +2 -2
  15. package/esm2015/src/application_init.js +10 -2
  16. package/esm2015/src/application_module.js +6 -3
  17. package/esm2015/src/application_ref.js +7 -7
  18. package/esm2015/src/core.js +4 -4
  19. package/esm2015/src/core_private_export.js +7 -7
  20. package/esm2015/src/core_render3_private_export.js +2 -2
  21. package/esm2015/src/debug/debug_node.js +55 -16
  22. package/esm2015/src/di/injectable.js +1 -13
  23. package/esm2015/src/di/injector.js +12 -10
  24. package/esm2015/src/di/interface/provider.js +1 -1
  25. package/esm2015/src/di/r3_injector.js +5 -4
  26. package/esm2015/src/i18n/locale_data_api.js +22 -6
  27. package/esm2015/src/i18n/locale_en.js +16 -5
  28. package/esm2015/src/i18n/localization.js +7 -1
  29. package/esm2015/src/i18n/tokens.js +41 -1
  30. package/esm2015/src/interface/type.js +1 -1
  31. package/esm2015/src/metadata/ng_module.js +1 -1
  32. package/esm2015/src/render/api.js +4 -1
  33. package/esm2015/src/render3/assert.js +9 -1
  34. package/esm2015/src/render3/bindings.js +16 -5
  35. package/esm2015/src/render3/component.js +54 -25
  36. package/esm2015/src/render3/component_ref.js +28 -18
  37. package/esm2015/src/render3/definition.js +3 -1
  38. package/esm2015/src/render3/di.js +3 -4
  39. package/esm2015/src/render3/di_setup.js +5 -7
  40. package/esm2015/src/render3/errors.js +3 -1
  41. package/esm2015/src/render3/features/inherit_definition_feature.js +89 -52
  42. package/esm2015/src/render3/features/ng_onchanges_feature.js +2 -2
  43. package/esm2015/src/render3/global_utils_api.js +3 -3
  44. package/esm2015/src/render3/i18n.js +60 -56
  45. package/esm2015/src/render3/index.js +2 -2
  46. package/esm2015/src/render3/instructions/advance.js +10 -11
  47. package/esm2015/src/render3/instructions/all.js +4 -5
  48. package/esm2015/src/render3/instructions/attribute.js +12 -5
  49. package/esm2015/src/render3/instructions/attribute_interpolation.js +66 -14
  50. package/esm2015/src/render3/instructions/change_detection.js +8 -23
  51. package/esm2015/src/render3/instructions/class_map_interpolation.js +13 -12
  52. package/esm2015/src/render3/instructions/container.js +15 -12
  53. package/esm2015/src/render3/instructions/element.js +45 -132
  54. package/esm2015/src/render3/instructions/element_container.js +8 -10
  55. package/esm2015/src/render3/instructions/embedded_view.js +7 -7
  56. package/esm2015/src/render3/instructions/host_property.js +10 -7
  57. package/esm2015/src/render3/instructions/listener.js +18 -16
  58. package/esm2015/src/render3/instructions/lview_debug.js +160 -23
  59. package/esm2015/src/render3/instructions/projection.js +7 -5
  60. package/esm2015/src/render3/instructions/property.js +27 -6
  61. package/esm2015/src/render3/instructions/property_interpolation.js +42 -23
  62. package/esm2015/src/render3/instructions/shared.js +279 -244
  63. package/esm2015/src/render3/instructions/storage.js +6 -8
  64. package/esm2015/src/render3/instructions/style_prop_interpolation.js +12 -12
  65. package/esm2015/src/render3/instructions/styling.js +731 -475
  66. package/esm2015/src/render3/instructions/text.js +5 -5
  67. package/esm2015/src/render3/interfaces/definition.js +41 -1
  68. package/esm2015/src/render3/interfaces/node.js +160 -115
  69. package/esm2015/src/render3/interfaces/styling.js +183 -375
  70. package/esm2015/src/render3/interfaces/view.js +10 -2
  71. package/esm2015/src/render3/jit/environment.js +1 -3
  72. package/esm2015/src/render3/namespaces.js +17 -0
  73. package/esm2015/src/render3/node_manipulation.js +177 -57
  74. package/esm2015/src/render3/node_selector_matcher.js +128 -24
  75. package/esm2015/src/render3/node_util.js +12 -7
  76. package/esm2015/src/render3/pipe.js +10 -14
  77. package/esm2015/src/render3/pure_function.js +107 -42
  78. package/esm2015/src/render3/query.js +32 -26
  79. package/esm2015/src/render3/state.js +57 -185
  80. package/esm2015/src/render3/styling/class_differ.js +47 -0
  81. package/esm2015/src/render3/styling/static_styling.js +54 -0
  82. package/esm2015/src/render3/styling/style_binding_list.js +437 -0
  83. package/esm2015/src/render3/styling/styling_parser.js +336 -0
  84. package/esm2015/src/render3/tokens.js +2 -2
  85. package/esm2015/src/render3/util/attrs_utils.js +125 -2
  86. package/esm2015/src/render3/util/change_detection_utils.js +33 -0
  87. package/esm2015/src/render3/util/discovery_utils.js +146 -119
  88. package/esm2015/src/render3/util/global_utils.js +5 -5
  89. package/esm2015/src/render3/util/view_utils.js +6 -6
  90. package/esm2015/src/render3/view_engine_compatibility.js +16 -17
  91. package/esm2015/src/render3/view_ref.js +16 -13
  92. package/esm2015/src/sanitization/bypass.js +1 -1
  93. package/esm2015/src/sanitization/sanitization.js +20 -5
  94. package/esm2015/src/util/array_utils.js +240 -1
  95. package/esm2015/src/util/assert.js +37 -21
  96. package/esm2015/src/util/char_code.js +8 -0
  97. package/esm2015/src/util/iterable.js +4 -1
  98. package/esm2015/src/util/ng_dev_mode.js +1 -12
  99. package/esm2015/src/util/stringify.js +14 -1
  100. package/esm2015/src/version.js +1 -1
  101. package/esm2015/src/view/services.js +1 -1
  102. package/esm2015/testing/src/r3_test_bed.js +5 -1
  103. package/esm2015/testing/src/r3_test_bed_compiler.js +5 -13
  104. package/esm2015/testing/src/styling.js +103 -0
  105. package/esm5/core.js +17 -15
  106. package/esm5/src/application_init.js +10 -2
  107. package/esm5/src/application_module.js +6 -3
  108. package/esm5/src/application_ref.js +6 -6
  109. package/esm5/src/core.js +2 -2
  110. package/esm5/src/core_private_export.js +7 -7
  111. package/esm5/src/core_render3_private_export.js +2 -2
  112. package/esm5/src/debug/debug_node.js +39 -14
  113. package/esm5/src/di/injectable.js +1 -1
  114. package/esm5/src/di/injector.js +12 -12
  115. package/esm5/src/di/interface/provider.js +1 -1
  116. package/esm5/src/di/r3_injector.js +5 -4
  117. package/esm5/src/i18n/locale_data_api.js +20 -6
  118. package/esm5/src/i18n/locale_en.js +16 -5
  119. package/esm5/src/i18n/localization.js +6 -1
  120. package/esm5/src/i18n/tokens.js +40 -1
  121. package/esm5/src/interface/type.js +1 -1
  122. package/esm5/src/metadata/ng_module.js +1 -1
  123. package/esm5/src/render/api.js +4 -1
  124. package/esm5/src/render3/assert.js +4 -1
  125. package/esm5/src/render3/bindings.js +19 -2
  126. package/esm5/src/render3/component.js +47 -22
  127. package/esm5/src/render3/component_ref.js +20 -17
  128. package/esm5/src/render3/definition.js +3 -1
  129. package/esm5/src/render3/di.js +3 -4
  130. package/esm5/src/render3/di_setup.js +4 -5
  131. package/esm5/src/render3/errors.js +3 -1
  132. package/esm5/src/render3/features/inherit_definition_feature.js +74 -42
  133. package/esm5/src/render3/features/ng_onchanges_feature.js +1 -1
  134. package/esm5/src/render3/global_utils_api.js +3 -3
  135. package/esm5/src/render3/i18n.js +51 -51
  136. package/esm5/src/render3/index.js +2 -2
  137. package/esm5/src/render3/instructions/advance.js +9 -11
  138. package/esm5/src/render3/instructions/all.js +1 -2
  139. package/esm5/src/render3/instructions/attribute.js +9 -5
  140. package/esm5/src/render3/instructions/attribute_interpolation.js +49 -13
  141. package/esm5/src/render3/instructions/change_detection.js +8 -21
  142. package/esm5/src/render3/instructions/class_map_interpolation.js +13 -12
  143. package/esm5/src/render3/instructions/container.js +13 -12
  144. package/esm5/src/render3/instructions/element.js +41 -113
  145. package/esm5/src/render3/instructions/element_container.js +8 -9
  146. package/esm5/src/render3/instructions/embedded_view.js +7 -7
  147. package/esm5/src/render3/instructions/host_property.js +8 -7
  148. package/esm5/src/render3/instructions/listener.js +13 -13
  149. package/esm5/src/render3/instructions/lview_debug.js +56 -15
  150. package/esm5/src/render3/instructions/projection.js +6 -5
  151. package/esm5/src/render3/instructions/property.js +17 -6
  152. package/esm5/src/render3/instructions/property_interpolation.js +32 -24
  153. package/esm5/src/render3/instructions/shared.js +258 -210
  154. package/esm5/src/render3/instructions/storage.js +4 -6
  155. package/esm5/src/render3/instructions/style_prop_interpolation.js +12 -12
  156. package/esm5/src/render3/instructions/styling.js +685 -367
  157. package/esm5/src/render3/instructions/text.js +5 -5
  158. package/esm5/src/render3/interfaces/definition.js +1 -1
  159. package/esm5/src/render3/interfaces/node.js +49 -1
  160. package/esm5/src/render3/interfaces/styling.js +57 -1
  161. package/esm5/src/render3/interfaces/view.js +1 -1
  162. package/esm5/src/render3/jit/environment.js +1 -3
  163. package/esm5/src/render3/namespaces.js +10 -0
  164. package/esm5/src/render3/node_manipulation.js +167 -54
  165. package/esm5/src/render3/node_selector_matcher.js +113 -20
  166. package/esm5/src/render3/node_util.js +12 -7
  167. package/esm5/src/render3/pipe.js +10 -14
  168. package/esm5/src/render3/pure_function.js +103 -33
  169. package/esm5/src/render3/query.js +25 -24
  170. package/esm5/src/render3/state.js +37 -133
  171. package/esm5/src/render3/styling/class_differ.js +39 -0
  172. package/esm5/src/render3/styling/static_styling.js +42 -0
  173. package/esm5/src/render3/styling/style_binding_list.js +411 -0
  174. package/esm5/src/render3/styling/styling_parser.js +265 -0
  175. package/esm5/src/render3/tokens.js +2 -2
  176. package/esm5/src/render3/util/attrs_utils.js +117 -2
  177. package/esm5/src/render3/util/change_detection_utils.js +23 -0
  178. package/esm5/src/render3/util/discovery_utils.js +115 -99
  179. package/esm5/src/render3/util/global_utils.js +5 -5
  180. package/esm5/src/render3/util/view_utils.js +5 -5
  181. package/esm5/src/render3/view_engine_compatibility.js +37 -39
  182. package/esm5/src/render3/view_ref.js +14 -13
  183. package/esm5/src/sanitization/bypass.js +1 -1
  184. package/esm5/src/sanitization/sanitization.js +16 -5
  185. package/esm5/src/util/array_utils.js +240 -1
  186. package/esm5/src/util/assert.js +37 -21
  187. package/esm5/src/util/char_code.js +8 -0
  188. package/esm5/src/util/iterable.js +4 -1
  189. package/esm5/src/util/ng_dev_mode.js +1 -12
  190. package/esm5/src/util/stringify.js +14 -1
  191. package/esm5/src/version.js +1 -1
  192. package/esm5/src/view/services.js +1 -1
  193. package/esm5/testing/src/r3_test_bed.js +9 -1
  194. package/esm5/testing/src/r3_test_bed_compiler.js +9 -15
  195. package/esm5/testing/src/styling.js +82 -0
  196. package/fesm2015/core.js +6431 -7075
  197. package/fesm2015/core.js.map +1 -1
  198. package/fesm2015/testing.js +10 -14
  199. package/fesm2015/testing.js.map +1 -1
  200. package/fesm5/core.js +6354 -6361
  201. package/fesm5/core.js.map +1 -1
  202. package/fesm5/testing.js +18 -16
  203. package/fesm5/testing.js.map +1 -1
  204. package/package.json +1 -1
  205. package/src/r3_symbols.d.ts +46 -23
  206. package/testing/testing.d.ts +3 -5
  207. package/testing/testing.metadata.json +1 -1
  208. package/testing.d.ts +2 -2
  209. package/esm2015/global.js +0 -7
  210. package/esm2015/src/render3/instructions/alloc_host_vars.js +0 -80
  211. package/esm2015/src/render3/styling/bindings.js +0 -1248
  212. package/esm2015/src/render3/styling/map_based_bindings.js +0 -384
  213. package/esm2015/src/render3/styling/state.js +0 -135
  214. package/esm2015/src/render3/styling/styling_debug.js +0 -655
  215. package/esm2015/src/render3/util/styling_utils.js +0 -625
  216. package/esm5/global.js +0 -9
  217. package/esm5/src/render3/instructions/alloc_host_vars.js +0 -62
  218. package/esm5/src/render3/styling/bindings.js +0 -949
  219. package/esm5/src/render3/styling/map_based_bindings.js +0 -310
  220. package/esm5/src/render3/styling/state.js +0 -56
  221. package/esm5/src/render3/styling/styling_debug.js +0 -315
  222. package/esm5/src/render3/util/styling_utils.js +0 -378
@@ -1,625 +0,0 @@
1
- /**
2
- * @fileoverview added by tsickle
3
- * Generated from: packages/core/src/render3/util/styling_utils.ts
4
- * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
5
- */
6
- /**
7
- * @license
8
- * Copyright Google Inc. All Rights Reserved.
9
- *
10
- * Use of this source code is governed by an MIT-style license that can be
11
- * found in the LICENSE file at https://angular.io/license
12
- */
13
- import { unwrapSafeValue } from '../../sanitization/bypass';
14
- import { NO_CHANGE } from '../tokens';
15
- /** @type {?} */
16
- export const MAP_BASED_ENTRY_PROP_NAME = '[MAP]';
17
- /** @type {?} */
18
- export const TEMPLATE_DIRECTIVE_INDEX = 0;
19
- /**
20
- * Default fallback value for a styling binding.
21
- *
22
- * A value of `null` is used here which signals to the styling algorithm that
23
- * the styling value is not present. This way if there are no other values
24
- * detected then it will be removed once the style/class property is dirty and
25
- * diffed within the styling algorithm present in `flushStyling`.
26
- * @type {?}
27
- */
28
- export const DEFAULT_BINDING_VALUE = null;
29
- /** @type {?} */
30
- export const DEFAULT_BINDING_INDEX = 0;
31
- /** @type {?} */
32
- const DEFAULT_TOTAL_SOURCES = 1;
33
- // The first bit value reflects a map-based binding value's bit.
34
- // The reason why it's always activated for every entry in the map
35
- // is so that if any map-binding values update then all other prop
36
- // based bindings will pass the guard check automatically without
37
- // any extra code or flags.
38
- /** @type {?} */
39
- export const DEFAULT_GUARD_MASK_VALUE = 0b1;
40
- /**
41
- * Creates a new instance of the `TStylingContext`.
42
- *
43
- * The `TStylingContext` is used as a manifest of all style or all class bindings on
44
- * an element. Because it is a T-level data-structure, it is only created once per
45
- * tNode for styles and for classes. This function allocates a new instance of a
46
- * `TStylingContext` with the initial values (see `interfaces.ts` for more info).
47
- * @param {?} initialStyling
48
- * @param {?} hasDirectives
49
- * @return {?}
50
- */
51
- export function allocTStylingContext(initialStyling, hasDirectives) {
52
- initialStyling = initialStyling || allocStylingMapArray(null);
53
- return [
54
- DEFAULT_TOTAL_SOURCES,
55
- initialStyling,
56
- ];
57
- }
58
- /**
59
- * @param {?} value
60
- * @return {?}
61
- */
62
- export function allocStylingMapArray(value) {
63
- return [value];
64
- }
65
- /**
66
- * @param {?} tNode
67
- * @param {?} flag
68
- * @return {?}
69
- */
70
- export function hasConfig(tNode, flag) {
71
- return (tNode.flags & flag) !== 0;
72
- }
73
- /**
74
- * Determines whether or not to apply styles/classes directly or via context resolution.
75
- *
76
- * There are three cases that are matched here:
77
- * 1. there are no directives present AND `ngDevMode` is falsy
78
- * 2. the `firstUpdatePass` has not already run (which means that
79
- * there are more bindings to register and, therefore, direct
80
- * style/class application is not yet possible)
81
- * 3. There are no collisions (i.e. properties with more than one binding) across multiple
82
- * sources (i.e. template + directive, directive + directive, directive + component)
83
- * @param {?} tNode
84
- * @param {?} isClassBased
85
- * @param {?} firstUpdatePass
86
- * @return {?}
87
- */
88
- export function allowDirectStyling(tNode, isClassBased, firstUpdatePass) {
89
- /** @type {?} */
90
- let allow = false;
91
- // if no directives are present then we do not need populate a context at all. This
92
- // is because duplicate prop bindings cannot be registered through the template. If
93
- // and when this happens we can safely apply the value directly without context
94
- // resolution...
95
- /** @type {?} */
96
- const hasDirectives = hasConfig(tNode, 128 /* hasHostBindings */);
97
- if (!hasDirectives) {
98
- // `ngDevMode` is required to be checked here because tests/debugging rely on the context being
99
- // populated. If things are in production mode then there is no need to build a context
100
- // therefore the direct apply can be allowed (even on the first update).
101
- allow = ngDevMode ? !firstUpdatePass : true;
102
- }
103
- else if (!firstUpdatePass) {
104
- /** @type {?} */
105
- const duplicateStylingFlag = isClassBased ? 8192 /* hasDuplicateClassBindings */ : 262144 /* hasDuplicateStyleBindings */;
106
- /** @type {?} */
107
- const hasDuplicates = hasConfig(tNode, duplicateStylingFlag);
108
- /** @type {?} */
109
- const hasOnlyMapOrPropsFlag = isClassBased ? 1536 /* hasClassPropAndMapBindings */ :
110
- 49152 /* hasStylePropAndMapBindings */;
111
- /** @type {?} */
112
- const hasOnlyMapsOrOnlyProps = (tNode.flags & hasOnlyMapOrPropsFlag) !== hasOnlyMapOrPropsFlag;
113
- allow = !hasDuplicates && hasOnlyMapsOrOnlyProps;
114
- }
115
- return allow;
116
- }
117
- /**
118
- * @param {?} tNode
119
- * @param {?} flag
120
- * @return {?}
121
- */
122
- export function patchConfig(tNode, flag) {
123
- tNode.flags |= flag;
124
- }
125
- /**
126
- * @param {?} context
127
- * @param {?} index
128
- * @return {?}
129
- */
130
- export function getProp(context, index) {
131
- return (/** @type {?} */ (context[index + 3 /* PropOffset */]));
132
- }
133
- /**
134
- * @param {?} context
135
- * @param {?} index
136
- * @return {?}
137
- */
138
- function getPropConfig(context, index) {
139
- return ((/** @type {?} */ (context[index + 0 /* ConfigOffset */]))) &
140
- 1 /* Mask */;
141
- }
142
- /**
143
- * @param {?} context
144
- * @param {?} index
145
- * @return {?}
146
- */
147
- export function isSanitizationRequired(context, index) {
148
- return (getPropConfig(context, index) & 1 /* SanitizationRequired */) !==
149
- 0;
150
- }
151
- /**
152
- * @param {?} context
153
- * @param {?} index
154
- * @param {?} isHostBinding
155
- * @return {?}
156
- */
157
- export function getGuardMask(context, index, isHostBinding) {
158
- /** @type {?} */
159
- const position = index + (isHostBinding ? 2 /* HostBindingsBitGuardOffset */ :
160
- 1 /* TemplateBitGuardOffset */);
161
- return (/** @type {?} */ (context[position]));
162
- }
163
- /**
164
- * @param {?} context
165
- * @param {?} index
166
- * @param {?} maskValue
167
- * @param {?} isHostBinding
168
- * @return {?}
169
- */
170
- export function setGuardMask(context, index, maskValue, isHostBinding) {
171
- /** @type {?} */
172
- const position = index + (isHostBinding ? 2 /* HostBindingsBitGuardOffset */ :
173
- 1 /* TemplateBitGuardOffset */);
174
- context[position] = maskValue;
175
- }
176
- /**
177
- * @param {?} context
178
- * @return {?}
179
- */
180
- export function getValuesCount(context) {
181
- return getTotalSources(context) + 1;
182
- }
183
- /**
184
- * @param {?} context
185
- * @return {?}
186
- */
187
- export function getTotalSources(context) {
188
- return context[0 /* TotalSourcesPosition */];
189
- }
190
- /**
191
- * @param {?} context
192
- * @param {?} index
193
- * @param {?} offset
194
- * @return {?}
195
- */
196
- export function getBindingValue(context, index, offset) {
197
- return (/** @type {?} */ (context[index + 4 /* BindingsStartOffset */ + offset]));
198
- }
199
- /**
200
- * @param {?} context
201
- * @param {?} index
202
- * @return {?}
203
- */
204
- export function getDefaultValue(context, index) {
205
- return (/** @type {?} */ (context[index + 4 /* BindingsStartOffset */ + getTotalSources(context)]));
206
- }
207
- /**
208
- * @param {?} context
209
- * @param {?} index
210
- * @param {?} value
211
- * @return {?}
212
- */
213
- export function setDefaultValue(context, index, value) {
214
- return context[index + 4 /* BindingsStartOffset */ + getTotalSources(context)] =
215
- value;
216
- }
217
- /**
218
- * @param {?} data
219
- * @param {?} bindingIndex
220
- * @param {?} value
221
- * @return {?}
222
- */
223
- export function setValue(data, bindingIndex, value) {
224
- data[bindingIndex] = value;
225
- }
226
- /**
227
- * @template T
228
- * @param {?} data
229
- * @param {?} bindingIndex
230
- * @return {?}
231
- */
232
- export function getValue(data, bindingIndex) {
233
- return bindingIndex !== 0 ? (/** @type {?} */ (data[bindingIndex])) : null;
234
- }
235
- /**
236
- * @param {?} context
237
- * @param {?} tNode
238
- * @param {?} isClassBased
239
- * @return {?}
240
- */
241
- export function getPropValuesStartPosition(context, tNode, isClassBased) {
242
- /** @type {?} */
243
- let startPosition = 2 /* ValuesStartPosition */;
244
- /** @type {?} */
245
- const flag = isClassBased ? 512 /* hasClassMapBindings */ : 16384 /* hasStyleMapBindings */;
246
- if (hasConfig(tNode, flag)) {
247
- startPosition += 4 /* BindingsStartOffset */ + getValuesCount(context);
248
- }
249
- return startPosition;
250
- }
251
- /**
252
- * @param {?} a
253
- * @param {?} b
254
- * @return {?}
255
- */
256
- export function hasValueChangedUnwrapSafeValue(a, b) {
257
- return hasValueChanged(unwrapSafeValue(a), unwrapSafeValue(b));
258
- }
259
- /**
260
- * @param {?} a
261
- * @param {?} b
262
- * @return {?}
263
- */
264
- export function hasValueChanged(a, b) {
265
- if (b === NO_CHANGE)
266
- return false;
267
- /** @type {?} */
268
- const compareValueA = Array.isArray(a) ? a[0 /* RawValuePosition */] : a;
269
- /** @type {?} */
270
- const compareValueB = Array.isArray(b) ? b[0 /* RawValuePosition */] : b;
271
- return !Object.is(compareValueA, compareValueB);
272
- }
273
- /**
274
- * Determines whether the provided styling value is truthy or falsy.
275
- * @template T
276
- * @param {?} value
277
- * @return {?}
278
- */
279
- export function isStylingValueDefined(value) {
280
- // the reason why null is compared against is because
281
- // a CSS class value that is set to `false` must be
282
- // respected (otherwise it would be treated as falsy).
283
- // Empty string values are because developers usually
284
- // set a value to an empty string to remove it.
285
- return value != null && value !== '';
286
- }
287
- /**
288
- * @param {?} a
289
- * @param {?} b
290
- * @param {?=} separator
291
- * @return {?}
292
- */
293
- export function concatString(a, b, separator = ' ') {
294
- return a + ((b.length && a.length) ? separator : '') + b;
295
- }
296
- /**
297
- * @param {?} value
298
- * @return {?}
299
- */
300
- export function hyphenate(value) {
301
- return value.replace(/[a-z][A-Z]/g, (/**
302
- * @param {?} v
303
- * @return {?}
304
- */
305
- v => v.charAt(0) + '-' + v.charAt(1))).toLowerCase();
306
- }
307
- /**
308
- * Returns an instance of `StylingMapArray`.
309
- *
310
- * This function is designed to find an instance of `StylingMapArray` in case it is stored
311
- * inside of an instance of `TStylingContext`. When a styling context is created it
312
- * will copy over an initial styling values from the tNode (which are stored as a
313
- * `StylingMapArray` on the `tNode.classes` or `tNode.styles` values).
314
- * @param {?} value
315
- * @return {?}
316
- */
317
- export function getStylingMapArray(value) {
318
- return isStylingContext(value) ?
319
- ((/** @type {?} */ (value)))[1 /* InitialStylingValuePosition */] :
320
- (/** @type {?} */ (value));
321
- }
322
- /**
323
- * @param {?} value
324
- * @return {?}
325
- */
326
- export function isStylingContext(value) {
327
- // the StylingMapArray is in the format of [initial, prop, string, prop, string]
328
- // and this is the defining value to distinguish between arrays
329
- return Array.isArray(value) && value.length >= 2 /* ValuesStartPosition */ &&
330
- typeof value[1] !== 'string';
331
- }
332
- /**
333
- * @param {?} value
334
- * @return {?}
335
- */
336
- export function isStylingMapArray(value) {
337
- // the StylingMapArray is in the format of [initial, prop, string, prop, string]
338
- // and this is the defining value to distinguish between arrays
339
- return Array.isArray(value) &&
340
- (typeof ((/** @type {?} */ (value)))[1 /* ValuesStartPosition */] === 'string');
341
- }
342
- /**
343
- * @param {?} context
344
- * @return {?}
345
- */
346
- export function getInitialStylingValue(context) {
347
- /** @type {?} */
348
- const map = getStylingMapArray(context);
349
- return map && ((/** @type {?} */ (map[0 /* RawValuePosition */]))) || '';
350
- }
351
- /**
352
- * @param {?} tNode
353
- * @return {?}
354
- */
355
- export function hasClassInput(tNode) {
356
- return (tNode.flags & 16 /* hasClassInput */) !== 0;
357
- }
358
- /**
359
- * @param {?} tNode
360
- * @return {?}
361
- */
362
- export function hasStyleInput(tNode) {
363
- return (tNode.flags & 32 /* hasStyleInput */) !== 0;
364
- }
365
- /**
366
- * @param {?} map
367
- * @param {?} index
368
- * @return {?}
369
- */
370
- export function getMapProp(map, index) {
371
- return (/** @type {?} */ (map[index + 0 /* PropOffset */]));
372
- }
373
- /** @type {?} */
374
- const MAP_DIRTY_VALUE = typeof ngDevMode !== 'undefined' && ngDevMode ? {} : { MAP_DIRTY_VALUE: true };
375
- /**
376
- * @param {?} map
377
- * @return {?}
378
- */
379
- export function setMapAsDirty(map) {
380
- map[0 /* RawValuePosition */] = MAP_DIRTY_VALUE;
381
- }
382
- /**
383
- * @param {?} map
384
- * @param {?} index
385
- * @param {?} value
386
- * @return {?}
387
- */
388
- export function setMapValue(map, index, value) {
389
- map[index + 1 /* ValueOffset */] = value;
390
- }
391
- /**
392
- * @param {?} map
393
- * @param {?} index
394
- * @return {?}
395
- */
396
- export function getMapValue(map, index) {
397
- return (/** @type {?} */ (map[index + 1 /* ValueOffset */]));
398
- }
399
- /**
400
- * @param {?} classes
401
- * @return {?}
402
- */
403
- export function forceClassesAsString(classes) {
404
- if (classes && typeof classes !== 'string') {
405
- classes = Object.keys(classes).join(' ');
406
- }
407
- return ((/** @type {?} */ (classes))) || '';
408
- }
409
- /**
410
- * @param {?} styles
411
- * @param {?} hyphenateProps
412
- * @return {?}
413
- */
414
- export function forceStylesAsString(styles, hyphenateProps) {
415
- if (typeof styles == 'string')
416
- return styles;
417
- /** @type {?} */
418
- let str = '';
419
- if (styles) {
420
- /** @type {?} */
421
- const props = Object.keys(styles);
422
- for (let i = 0; i < props.length; i++) {
423
- /** @type {?} */
424
- const prop = props[i];
425
- /** @type {?} */
426
- const propLabel = hyphenateProps ? hyphenate(prop) : prop;
427
- /** @type {?} */
428
- const value = styles[prop];
429
- if (value !== null) {
430
- str = concatString(str, `${propLabel}:${value}`, ';');
431
- }
432
- }
433
- }
434
- return str;
435
- }
436
- /**
437
- * @param {?} directiveOrSourceId
438
- * @return {?}
439
- */
440
- export function isHostStylingActive(directiveOrSourceId) {
441
- return directiveOrSourceId !== TEMPLATE_DIRECTIVE_INDEX;
442
- }
443
- /**
444
- * Converts the provided styling map array into a string.
445
- *
446
- * Classes => `one two three`
447
- * Styles => `prop:value; prop2:value2`
448
- * @param {?} map
449
- * @param {?} isClassBased
450
- * @return {?}
451
- */
452
- export function stylingMapToString(map, isClassBased) {
453
- /** @type {?} */
454
- let str = '';
455
- for (let i = 1 /* ValuesStartPosition */; i < map.length; i += 2 /* TupleSize */) {
456
- /** @type {?} */
457
- const prop = getMapProp(map, i);
458
- /** @type {?} */
459
- const value = (/** @type {?} */ (getMapValue(map, i)));
460
- /** @type {?} */
461
- const attrValue = concatString(prop, isClassBased ? '' : value, ':');
462
- str = concatString(str, attrValue, isClassBased ? ' ' : '; ');
463
- }
464
- return str;
465
- }
466
- /**
467
- * Converts the provided styling map array into a key value map.
468
- * @param {?} map
469
- * @return {?}
470
- */
471
- export function stylingMapToStringMap(map) {
472
- /** @type {?} */
473
- let stringMap = {};
474
- if (map) {
475
- for (let i = 1 /* ValuesStartPosition */; i < map.length; i += 2 /* TupleSize */) {
476
- /** @type {?} */
477
- const prop = getMapProp(map, i);
478
- /** @type {?} */
479
- const value = (/** @type {?} */ (getMapValue(map, i)));
480
- stringMap[prop] = value;
481
- }
482
- }
483
- return stringMap;
484
- }
485
- /**
486
- * Inserts the provided item into the provided styling array at the right spot.
487
- *
488
- * The `StylingMapArray` type is a sorted key/value array of entries. This means
489
- * that when a new entry is inserted it must be placed at the right spot in the
490
- * array. This function figures out exactly where to place it.
491
- * @param {?} stylingMapArr
492
- * @param {?} prop
493
- * @param {?} value
494
- * @param {?=} allowOverwrite
495
- * @return {?}
496
- */
497
- export function addItemToStylingMap(stylingMapArr, prop, value, allowOverwrite) {
498
- for (let j = 1 /* ValuesStartPosition */; j < stylingMapArr.length; j += 2 /* TupleSize */) {
499
- /** @type {?} */
500
- const propAtIndex = getMapProp(stylingMapArr, j);
501
- if (prop <= propAtIndex) {
502
- /** @type {?} */
503
- let applied = false;
504
- if (propAtIndex === prop) {
505
- /** @type {?} */
506
- const valueAtIndex = stylingMapArr[j];
507
- if (allowOverwrite || !isStylingValueDefined(valueAtIndex)) {
508
- applied = true;
509
- setMapValue(stylingMapArr, j, value);
510
- }
511
- }
512
- else {
513
- applied = true;
514
- stylingMapArr.splice(j, 0, prop, value);
515
- }
516
- return applied;
517
- }
518
- }
519
- stylingMapArr.push(prop, value);
520
- return true;
521
- }
522
- /**
523
- * Used to convert a {key:value} map into a `StylingMapArray` array.
524
- *
525
- * This function will either generate a new `StylingMapArray` instance
526
- * or it will patch the provided `newValues` map value into an
527
- * existing `StylingMapArray` value (this only happens if `bindingValue`
528
- * is an instance of `StylingMapArray`).
529
- *
530
- * If a new key/value map is provided with an old `StylingMapArray`
531
- * value then all properties will be overwritten with their new
532
- * values or with `null`. This means that the array will never
533
- * shrink in size (but it will also not be created and thrown
534
- * away whenever the `{key:value}` map entries change).
535
- * @param {?} bindingValue
536
- * @param {?} newValues
537
- * @param {?=} normalizeProps
538
- * @return {?}
539
- */
540
- export function normalizeIntoStylingMap(bindingValue, newValues, normalizeProps) {
541
- /** @type {?} */
542
- const stylingMapArr = Array.isArray(bindingValue) ? bindingValue : allocStylingMapArray(null);
543
- stylingMapArr[0 /* RawValuePosition */] = newValues;
544
- // because the new values may not include all the properties
545
- // that the old ones had, all values are set to `null` before
546
- // the new values are applied. This way, when flushed, the
547
- // styling algorithm knows exactly what style/class values
548
- // to remove from the element (since they are `null`).
549
- for (let j = 1 /* ValuesStartPosition */; j < stylingMapArr.length; j += 2 /* TupleSize */) {
550
- setMapValue(stylingMapArr, j, null);
551
- }
552
- /** @type {?} */
553
- let props = null;
554
- /** @type {?} */
555
- let map;
556
- /** @type {?} */
557
- let allValuesTrue = false;
558
- if (typeof newValues === 'string') { // [class] bindings allow string values
559
- props = splitOnWhitespace(newValues);
560
- allValuesTrue = props !== null;
561
- }
562
- else {
563
- props = newValues ? Object.keys(newValues) : null;
564
- map = newValues;
565
- }
566
- if (props) {
567
- for (let i = 0; i < props.length; i++) {
568
- /** @type {?} */
569
- const prop = props[i];
570
- /** @type {?} */
571
- const newProp = normalizeProps ? hyphenate(prop) : prop;
572
- /** @type {?} */
573
- const value = allValuesTrue ? true : (/** @type {?} */ (map))[prop];
574
- addItemToStylingMap(stylingMapArr, newProp, value, true);
575
- }
576
- }
577
- return stylingMapArr;
578
- }
579
- /**
580
- * @param {?} text
581
- * @return {?}
582
- */
583
- export function splitOnWhitespace(text) {
584
- /** @type {?} */
585
- let array = null;
586
- /** @type {?} */
587
- let length = text.length;
588
- /** @type {?} */
589
- let start = 0;
590
- /** @type {?} */
591
- let foundChar = false;
592
- for (let i = 0; i < length; i++) {
593
- /** @type {?} */
594
- const char = text.charCodeAt(i);
595
- if (char <= 32 /*' '*/) {
596
- if (foundChar) {
597
- if (array === null)
598
- array = [];
599
- array.push(text.substring(start, i));
600
- foundChar = false;
601
- }
602
- start = i + 1;
603
- }
604
- else {
605
- foundChar = true;
606
- }
607
- }
608
- if (foundChar) {
609
- if (array === null)
610
- array = [];
611
- array.push(text.substring(start, length));
612
- foundChar = false;
613
- }
614
- return array;
615
- }
616
- // TODO (matsko|AndrewKushnir): refactor this once we figure out how to generate separate
617
- // `input('class') + classMap()` instructions.
618
- /**
619
- * @param {?} inputs
620
- * @return {?}
621
- */
622
- export function selectClassBasedInputName(inputs) {
623
- return inputs.hasOwnProperty('class') ? 'class' : 'className';
624
- }
625
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"styling_utils.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/util/styling_utils.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 {unwrapSafeValue} from '../../sanitization/bypass';\nimport {PropertyAliases, TNodeFlags} from '../interfaces/node';\nimport {LStylingData, StylingMapArray, StylingMapArrayIndex, TStylingContext, TStylingContextIndex, TStylingContextPropConfigFlags, TStylingNode} from '../interfaces/styling';\nimport {NO_CHANGE} from '../tokens';\n\nexport const MAP_BASED_ENTRY_PROP_NAME = '[MAP]';\nexport const TEMPLATE_DIRECTIVE_INDEX = 0;\n\n/**\n * Default fallback value for a styling binding.\n *\n * A value of `null` is used here which signals to the styling algorithm that\n * the styling value is not present. This way if there are no other values\n * detected then it will be removed once the style/class property is dirty and\n * diffed within the styling algorithm present in `flushStyling`.\n */\nexport const DEFAULT_BINDING_VALUE = null;\n\nexport const DEFAULT_BINDING_INDEX = 0;\n\nconst DEFAULT_TOTAL_SOURCES = 1;\n\n// The first bit value reflects a map-based binding value's bit.\n// The reason why it's always activated for every entry in the map\n// is so that if any map-binding values update then all other prop\n// based bindings will pass the guard check automatically without\n// any extra code or flags.\nexport const DEFAULT_GUARD_MASK_VALUE = 0b1;\n\n/**\n * Creates a new instance of the `TStylingContext`.\n *\n * The `TStylingContext` is used as a manifest of all style or all class bindings on\n * an element. Because it is a T-level data-structure, it is only created once per\n * tNode for styles and for classes. This function allocates a new instance of a\n * `TStylingContext` with the initial values (see `interfaces.ts` for more info).\n */\nexport function allocTStylingContext(\n    initialStyling: StylingMapArray | null, hasDirectives: boolean): TStylingContext {\n  initialStyling = initialStyling || allocStylingMapArray(null);\n  return [\n    DEFAULT_TOTAL_SOURCES,  // 1) total amount of styling sources (template, directives, etc...)\n    initialStyling,         // 2) initial styling values\n  ];\n}\n\nexport function allocStylingMapArray(value: {} | string | null): StylingMapArray {\n  return [value];\n}\n\nexport function hasConfig(tNode: TStylingNode, flag: TNodeFlags) {\n  return (tNode.flags & flag) !== 0;\n}\n\n/**\n * Determines whether or not to apply styles/classes directly or via context resolution.\n *\n * There are three cases that are matched here:\n * 1. there are no directives present AND `ngDevMode` is falsy\n * 2. the `firstUpdatePass` has not already run (which means that\n *    there are more bindings to register and, therefore, direct\n *    style/class application is not yet possible)\n * 3. There are no collisions (i.e. properties with more than one binding) across multiple\n *    sources (i.e. template + directive, directive + directive, directive + component)\n */\nexport function allowDirectStyling(\n    tNode: TStylingNode, isClassBased: boolean, firstUpdatePass: boolean): boolean {\n  let allow = false;\n\n  // if no directives are present then we do not need populate a context at all. This\n  // is because duplicate prop bindings cannot be registered through the template. If\n  // and when this happens we can safely apply the value directly without context\n  // resolution...\n  const hasDirectives = hasConfig(tNode, TNodeFlags.hasHostBindings);\n  if (!hasDirectives) {\n    // `ngDevMode` is required to be checked here because tests/debugging rely on the context being\n    // populated. If things are in production mode then there is no need to build a context\n    // therefore the direct apply can be allowed (even on the first update).\n    allow = ngDevMode ? !firstUpdatePass : true;\n  } else if (!firstUpdatePass) {\n    const duplicateStylingFlag =\n        isClassBased ? TNodeFlags.hasDuplicateClassBindings : TNodeFlags.hasDuplicateStyleBindings;\n    const hasDuplicates = hasConfig(tNode, duplicateStylingFlag);\n    const hasOnlyMapOrPropsFlag = isClassBased ? TNodeFlags.hasClassPropAndMapBindings :\n                                                 TNodeFlags.hasStylePropAndMapBindings;\n    const hasOnlyMapsOrOnlyProps = (tNode.flags & hasOnlyMapOrPropsFlag) !== hasOnlyMapOrPropsFlag;\n    allow = !hasDuplicates && hasOnlyMapsOrOnlyProps;\n  }\n\n  return allow;\n}\n\nexport function patchConfig(tNode: TStylingNode, flag: TNodeFlags): void {\n  tNode.flags |= flag;\n}\n\nexport function getProp(context: TStylingContext, index: number): string {\n  return context[index + TStylingContextIndex.PropOffset] as string;\n}\n\nfunction getPropConfig(context: TStylingContext, index: number): number {\n  return (context[index + TStylingContextIndex.ConfigOffset] as number) &\n      TStylingContextPropConfigFlags.Mask;\n}\n\nexport function isSanitizationRequired(context: TStylingContext, index: number): boolean {\n  return (getPropConfig(context, index) & TStylingContextPropConfigFlags.SanitizationRequired) !==\n      0;\n}\n\nexport function getGuardMask(\n    context: TStylingContext, index: number, isHostBinding: boolean): number {\n  const position = index + (isHostBinding ? TStylingContextIndex.HostBindingsBitGuardOffset :\n                                            TStylingContextIndex.TemplateBitGuardOffset);\n  return context[position] as number;\n}\n\nexport function setGuardMask(\n    context: TStylingContext, index: number, maskValue: number, isHostBinding: boolean) {\n  const position = index + (isHostBinding ? TStylingContextIndex.HostBindingsBitGuardOffset :\n                                            TStylingContextIndex.TemplateBitGuardOffset);\n  context[position] = maskValue;\n}\n\nexport function getValuesCount(context: TStylingContext): number {\n  return getTotalSources(context) + 1;\n}\n\nexport function getTotalSources(context: TStylingContext): number {\n  return context[TStylingContextIndex.TotalSourcesPosition];\n}\n\nexport function getBindingValue(context: TStylingContext, index: number, offset: number) {\n  return context[index + TStylingContextIndex.BindingsStartOffset + offset] as number | string;\n}\n\nexport function getDefaultValue(context: TStylingContext, index: number): string|boolean|null {\n  return context[index + TStylingContextIndex.BindingsStartOffset + getTotalSources(context)] as\n             string |\n      boolean | null;\n}\n\nexport function setDefaultValue(\n    context: TStylingContext, index: number, value: string | boolean | null) {\n  return context[index + TStylingContextIndex.BindingsStartOffset + getTotalSources(context)] =\n             value;\n}\n\nexport function setValue(data: LStylingData, bindingIndex: number, value: any) {\n  data[bindingIndex] = value;\n}\n\nexport function getValue<T = any>(data: LStylingData, bindingIndex: number): T|null {\n  return bindingIndex !== 0 ? data[bindingIndex] as T : null;\n}\n\nexport function getPropValuesStartPosition(\n    context: TStylingContext, tNode: TStylingNode, isClassBased: boolean) {\n  let startPosition = TStylingContextIndex.ValuesStartPosition;\n  const flag = isClassBased ? TNodeFlags.hasClassMapBindings : TNodeFlags.hasStyleMapBindings;\n  if (hasConfig(tNode, flag)) {\n    startPosition += TStylingContextIndex.BindingsStartOffset + getValuesCount(context);\n  }\n  return startPosition;\n}\n\nexport function hasValueChangedUnwrapSafeValue(\n    a: NO_CHANGE | StylingMapArray | number | String | string | null | boolean | undefined | {},\n    b: NO_CHANGE | StylingMapArray | number | String | string | null | boolean | undefined |\n        {}): boolean {\n  return hasValueChanged(unwrapSafeValue(a), unwrapSafeValue(b));\n}\n\n\nexport function hasValueChanged(\n    a: NO_CHANGE | StylingMapArray | number | string | null | boolean | undefined | {},\n    b: NO_CHANGE | StylingMapArray | number | string | null | boolean | undefined | {}): boolean {\n  if (b === NO_CHANGE) return false;\n\n  const compareValueA = Array.isArray(a) ? a[StylingMapArrayIndex.RawValuePosition] : a;\n  const compareValueB = Array.isArray(b) ? b[StylingMapArrayIndex.RawValuePosition] : b;\n  return !Object.is(compareValueA, compareValueB);\n}\n\n/**\n * Determines whether the provided styling value is truthy or falsy.\n */\nexport function isStylingValueDefined<T extends string|number|{}|null|undefined>(value: T):\n    value is NonNullable<T> {\n  // the reason why null is compared against is because\n  // a CSS class value that is set to `false` must be\n  // respected (otherwise it would be treated as falsy).\n  // Empty string values are because developers usually\n  // set a value to an empty string to remove it.\n  return value != null && value !== '';\n}\n\nexport function concatString(a: string, b: string, separator = ' '): string {\n  return a + ((b.length && a.length) ? separator : '') + b;\n}\n\nexport function hyphenate(value: string): string {\n  return value.replace(/[a-z][A-Z]/g, v => v.charAt(0) + '-' + v.charAt(1)).toLowerCase();\n}\n\n/**\n * Returns an instance of `StylingMapArray`.\n *\n * This function is designed to find an instance of `StylingMapArray` in case it is stored\n * inside of an instance of `TStylingContext`. When a styling context is created it\n * will copy over an initial styling values from the tNode (which are stored as a\n * `StylingMapArray` on the `tNode.classes` or `tNode.styles` values).\n */\nexport function getStylingMapArray(value: TStylingContext | StylingMapArray | null):\n    StylingMapArray|null {\n  return isStylingContext(value) ?\n      (value as TStylingContext)[TStylingContextIndex.InitialStylingValuePosition] :\n      value as StylingMapArray;\n}\n\nexport function isStylingContext(value: any): boolean {\n  // the StylingMapArray is in the format of [initial, prop, string, prop, string]\n  // and this is the defining value to distinguish between arrays\n  return Array.isArray(value) && value.length >= TStylingContextIndex.ValuesStartPosition &&\n      typeof value[1] !== 'string';\n}\n\nexport function isStylingMapArray(value: any): boolean {\n  // the StylingMapArray is in the format of [initial, prop, string, prop, string]\n  // and this is the defining value to distinguish between arrays\n  return Array.isArray(value) &&\n      (typeof(value as StylingMapArray)[StylingMapArrayIndex.ValuesStartPosition] === 'string');\n}\n\nexport function getInitialStylingValue(context: TStylingContext | StylingMapArray | null): string {\n  const map = getStylingMapArray(context);\n  return map && (map[StylingMapArrayIndex.RawValuePosition] as string | null) || '';\n}\n\nexport function hasClassInput(tNode: TStylingNode) {\n  return (tNode.flags & TNodeFlags.hasClassInput) !== 0;\n}\n\nexport function hasStyleInput(tNode: TStylingNode) {\n  return (tNode.flags & TNodeFlags.hasStyleInput) !== 0;\n}\n\nexport function getMapProp(map: StylingMapArray, index: number): string {\n  return map[index + StylingMapArrayIndex.PropOffset] as string;\n}\n\nconst MAP_DIRTY_VALUE =\n    typeof ngDevMode !== 'undefined' && ngDevMode ? {} : {MAP_DIRTY_VALUE: true};\n\nexport function setMapAsDirty(map: StylingMapArray): void {\n  map[StylingMapArrayIndex.RawValuePosition] = MAP_DIRTY_VALUE;\n}\n\nexport function setMapValue(\n    map: StylingMapArray, index: number, value: string | boolean | null): void {\n  map[index + StylingMapArrayIndex.ValueOffset] = value;\n}\n\nexport function getMapValue(map: StylingMapArray, index: number): string|null {\n  return map[index + StylingMapArrayIndex.ValueOffset] as string | null;\n}\n\nexport function forceClassesAsString(classes: string | {[key: string]: any} | null | undefined):\n    string {\n  if (classes && typeof classes !== 'string') {\n    classes = Object.keys(classes).join(' ');\n  }\n  return (classes as string) || '';\n}\n\nexport function forceStylesAsString(\n    styles: {[key: string]: any} | string | null | undefined, hyphenateProps: boolean): string {\n  if (typeof styles == 'string') return styles;\n  let str = '';\n  if (styles) {\n    const props = Object.keys(styles);\n    for (let i = 0; i < props.length; i++) {\n      const prop = props[i];\n      const propLabel = hyphenateProps ? hyphenate(prop) : prop;\n      const value = styles[prop];\n      if (value !== null) {\n        str = concatString(str, `${propLabel}:${value}`, ';');\n      }\n    }\n  }\n  return str;\n}\n\nexport function isHostStylingActive(directiveOrSourceId: number): boolean {\n  return directiveOrSourceId !== TEMPLATE_DIRECTIVE_INDEX;\n}\n\n/**\n * Converts the provided styling map array into a string.\n *\n * Classes => `one two three`\n * Styles => `prop:value; prop2:value2`\n */\nexport function stylingMapToString(map: StylingMapArray, isClassBased: boolean): string {\n  let str = '';\n  for (let i = StylingMapArrayIndex.ValuesStartPosition; i < map.length;\n       i += StylingMapArrayIndex.TupleSize) {\n    const prop = getMapProp(map, i);\n    const value = getMapValue(map, i) as string;\n    const attrValue = concatString(prop, isClassBased ? '' : value, ':');\n    str = concatString(str, attrValue, isClassBased ? ' ' : '; ');\n  }\n  return str;\n}\n\n/**\n * Converts the provided styling map array into a key value map.\n */\nexport function stylingMapToStringMap(map: StylingMapArray | null): {[key: string]: any} {\n  let stringMap: {[key: string]: any} = {};\n  if (map) {\n    for (let i = StylingMapArrayIndex.ValuesStartPosition; i < map.length;\n         i += StylingMapArrayIndex.TupleSize) {\n      const prop = getMapProp(map, i);\n      const value = getMapValue(map, i) as string;\n      stringMap[prop] = value;\n    }\n  }\n  return stringMap;\n}\n\n/**\n * Inserts the provided item into the provided styling array at the right spot.\n *\n * The `StylingMapArray` type is a sorted key/value array of entries. This means\n * that when a new entry is inserted it must be placed at the right spot in the\n * array. This function figures out exactly where to place it.\n */\nexport function addItemToStylingMap(\n    stylingMapArr: StylingMapArray, prop: string, value: string | boolean | null,\n    allowOverwrite?: boolean) {\n  for (let j = StylingMapArrayIndex.ValuesStartPosition; j < stylingMapArr.length;\n       j += StylingMapArrayIndex.TupleSize) {\n    const propAtIndex = getMapProp(stylingMapArr, j);\n    if (prop <= propAtIndex) {\n      let applied = false;\n      if (propAtIndex === prop) {\n        const valueAtIndex = stylingMapArr[j];\n        if (allowOverwrite || !isStylingValueDefined(valueAtIndex)) {\n          applied = true;\n          setMapValue(stylingMapArr, j, value);\n        }\n      } else {\n        applied = true;\n        stylingMapArr.splice(j, 0, prop, value);\n      }\n      return applied;\n    }\n  }\n\n  stylingMapArr.push(prop, value);\n  return true;\n}\n\n/**\n * Used to convert a {key:value} map into a `StylingMapArray` array.\n *\n * This function will either generate a new `StylingMapArray` instance\n * or it will patch the provided `newValues` map value into an\n * existing `StylingMapArray` value (this only happens if `bindingValue`\n * is an instance of `StylingMapArray`).\n *\n * If a new key/value map is provided with an old `StylingMapArray`\n * value then all properties will be overwritten with their new\n * values or with `null`. This means that the array will never\n * shrink in size (but it will also not be created and thrown\n * away whenever the `{key:value}` map entries change).\n */\nexport function normalizeIntoStylingMap(\n    bindingValue: null | StylingMapArray,\n    newValues: {[key: string]: any} | string | null | undefined,\n    normalizeProps?: boolean): StylingMapArray {\n  const stylingMapArr: StylingMapArray =\n      Array.isArray(bindingValue) ? bindingValue : allocStylingMapArray(null);\n  stylingMapArr[StylingMapArrayIndex.RawValuePosition] = newValues;\n\n  // because the new values may not include all the properties\n  // that the old ones had, all values are set to `null` before\n  // the new values are applied. This way, when flushed, the\n  // styling algorithm knows exactly what style/class values\n  // to remove from the element (since they are `null`).\n  for (let j = StylingMapArrayIndex.ValuesStartPosition; j < stylingMapArr.length;\n       j += StylingMapArrayIndex.TupleSize) {\n    setMapValue(stylingMapArr, j, null);\n  }\n\n  let props: string[]|null = null;\n  let map: {[key: string]: any}|undefined|null;\n  let allValuesTrue = false;\n  if (typeof newValues === 'string') {  // [class] bindings allow string values\n    props = splitOnWhitespace(newValues);\n    allValuesTrue = props !== null;\n  } else {\n    props = newValues ? Object.keys(newValues) : null;\n    map = newValues;\n  }\n\n  if (props) {\n    for (let i = 0; i < props.length; i++) {\n      const prop = props[i];\n      const newProp = normalizeProps ? hyphenate(prop) : prop;\n      const value = allValuesTrue ? true : map ![prop];\n      addItemToStylingMap(stylingMapArr, newProp, value, true);\n    }\n  }\n\n  return stylingMapArr;\n}\n\nexport function splitOnWhitespace(text: string): string[]|null {\n  let array: string[]|null = null;\n  let length = text.length;\n  let start = 0;\n  let foundChar = false;\n  for (let i = 0; i < length; i++) {\n    const char = text.charCodeAt(i);\n    if (char <= 32 /*' '*/) {\n      if (foundChar) {\n        if (array === null) array = [];\n        array.push(text.substring(start, i));\n        foundChar = false;\n      }\n      start = i + 1;\n    } else {\n      foundChar = true;\n    }\n  }\n  if (foundChar) {\n    if (array === null) array = [];\n    array.push(text.substring(start, length));\n    foundChar = false;\n  }\n  return array;\n}\n\n// TODO (matsko|AndrewKushnir): refactor this once we figure out how to generate separate\n// `input('class') + classMap()` instructions.\nexport function selectClassBasedInputName(inputs: PropertyAliases): string {\n  return inputs.hasOwnProperty('class') ? 'class' : 'className';\n}\n"]}