@angular/core 9.0.0-rc.6 → 9.0.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 (234) 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 +4018 -4002
  6. package/bundles/core.umd.js.map +1 -1
  7. package/bundles/core.umd.min.js +172 -187
  8. package/bundles/core.umd.min.js.map +1 -1
  9. package/core.d.ts +725 -735
  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 +71 -69
  22. package/esm2015/src/di/injectable.js +1 -13
  23. package/esm2015/src/di/injector.js +12 -10
  24. package/esm2015/src/di/interface/defs.js +28 -4
  25. package/esm2015/src/di/interface/provider.js +1 -1
  26. package/esm2015/src/di/jit/injectable.js +14 -2
  27. package/esm2015/src/di/jit/util.js +7 -5
  28. package/esm2015/src/di/r3_injector.js +5 -5
  29. package/esm2015/src/i18n/locale_data_api.js +22 -6
  30. package/esm2015/src/i18n/locale_en.js +16 -5
  31. package/esm2015/src/i18n/localization.js +7 -1
  32. package/esm2015/src/i18n/tokens.js +41 -1
  33. package/esm2015/src/interface/type.js +1 -1
  34. package/esm2015/src/metadata/ng_module.js +1 -1
  35. package/esm2015/src/render/api.js +4 -1
  36. package/esm2015/src/render3/assert.js +9 -1
  37. package/esm2015/src/render3/bindings.js +20 -7
  38. package/esm2015/src/render3/component.js +54 -25
  39. package/esm2015/src/render3/component_ref.js +17 -18
  40. package/esm2015/src/render3/definition.js +3 -1
  41. package/esm2015/src/render3/di.js +3 -4
  42. package/esm2015/src/render3/di_setup.js +5 -7
  43. package/esm2015/src/render3/errors.js +99 -19
  44. package/esm2015/src/render3/features/inherit_definition_feature.js +89 -52
  45. package/esm2015/src/render3/features/ng_onchanges_feature.js +2 -2
  46. package/esm2015/src/render3/global_utils_api.js +3 -3
  47. package/esm2015/src/render3/i18n.js +60 -56
  48. package/esm2015/src/render3/index.js +2 -2
  49. package/esm2015/src/render3/instructions/advance.js +10 -11
  50. package/esm2015/src/render3/instructions/all.js +4 -5
  51. package/esm2015/src/render3/instructions/attribute.js +12 -5
  52. package/esm2015/src/render3/instructions/attribute_interpolation.js +66 -14
  53. package/esm2015/src/render3/instructions/change_detection.js +8 -23
  54. package/esm2015/src/render3/instructions/class_map_interpolation.js +13 -12
  55. package/esm2015/src/render3/instructions/container.js +15 -12
  56. package/esm2015/src/render3/instructions/element.js +50 -133
  57. package/esm2015/src/render3/instructions/element_container.js +8 -10
  58. package/esm2015/src/render3/instructions/embedded_view.js +7 -7
  59. package/esm2015/src/render3/instructions/host_property.js +10 -7
  60. package/esm2015/src/render3/instructions/listener.js +18 -16
  61. package/esm2015/src/render3/instructions/lview_debug.js +160 -23
  62. package/esm2015/src/render3/instructions/projection.js +7 -5
  63. package/esm2015/src/render3/instructions/property.js +27 -6
  64. package/esm2015/src/render3/instructions/property_interpolation.js +42 -23
  65. package/esm2015/src/render3/instructions/shared.js +285 -245
  66. package/esm2015/src/render3/instructions/storage.js +6 -8
  67. package/esm2015/src/render3/instructions/style_prop_interpolation.js +12 -12
  68. package/esm2015/src/render3/instructions/styling.js +732 -470
  69. package/esm2015/src/render3/instructions/text.js +5 -5
  70. package/esm2015/src/render3/interfaces/definition.js +41 -1
  71. package/esm2015/src/render3/interfaces/node.js +160 -115
  72. package/esm2015/src/render3/interfaces/styling.js +183 -375
  73. package/esm2015/src/render3/interfaces/view.js +10 -2
  74. package/esm2015/src/render3/jit/directive.js +10 -16
  75. package/esm2015/src/render3/jit/environment.js +1 -3
  76. package/esm2015/src/render3/node_manipulation.js +177 -57
  77. package/esm2015/src/render3/node_selector_matcher.js +128 -24
  78. package/esm2015/src/render3/node_util.js +12 -7
  79. package/esm2015/src/render3/pipe.js +10 -14
  80. package/esm2015/src/render3/pure_function.js +107 -42
  81. package/esm2015/src/render3/query.js +32 -26
  82. package/esm2015/src/render3/state.js +54 -183
  83. package/esm2015/src/render3/styling/class_differ.js +47 -0
  84. package/esm2015/src/render3/styling/static_styling.js +54 -0
  85. package/esm2015/src/render3/styling/style_binding_list.js +437 -0
  86. package/esm2015/src/render3/styling/styling_parser.js +336 -0
  87. package/esm2015/src/render3/tokens.js +2 -2
  88. package/esm2015/src/render3/util/attrs_utils.js +125 -2
  89. package/esm2015/src/render3/util/change_detection_utils.js +33 -0
  90. package/esm2015/src/render3/util/discovery_utils.js +146 -119
  91. package/esm2015/src/render3/util/global_utils.js +5 -5
  92. package/esm2015/src/render3/util/view_utils.js +6 -6
  93. package/esm2015/src/render3/view_engine_compatibility.js +16 -17
  94. package/esm2015/src/render3/view_ref.js +16 -13
  95. package/esm2015/src/sanitization/bypass.js +1 -1
  96. package/esm2015/src/sanitization/inert_body.js +22 -18
  97. package/esm2015/src/sanitization/sanitization.js +20 -5
  98. package/esm2015/src/util/array_utils.js +240 -1
  99. package/esm2015/src/util/assert.js +37 -21
  100. package/esm2015/src/util/char_code.js +8 -0
  101. package/esm2015/src/util/iterable.js +4 -1
  102. package/esm2015/src/util/ng_dev_mode.js +1 -12
  103. package/esm2015/src/util/stringify.js +14 -1
  104. package/esm2015/src/version.js +1 -1
  105. package/esm2015/src/view/services.js +1 -1
  106. package/esm2015/testing/src/r3_test_bed.js +5 -1
  107. package/esm2015/testing/src/r3_test_bed_compiler.js +5 -13
  108. package/esm2015/testing/src/styling.js +103 -0
  109. package/esm5/core.js +17 -15
  110. package/esm5/src/application_init.js +10 -2
  111. package/esm5/src/application_module.js +6 -3
  112. package/esm5/src/application_ref.js +6 -6
  113. package/esm5/src/core.js +2 -2
  114. package/esm5/src/core_private_export.js +7 -7
  115. package/esm5/src/core_render3_private_export.js +2 -2
  116. package/esm5/src/debug/debug_node.js +47 -41
  117. package/esm5/src/di/injectable.js +1 -1
  118. package/esm5/src/di/injector.js +12 -12
  119. package/esm5/src/di/interface/defs.js +28 -4
  120. package/esm5/src/di/interface/provider.js +1 -1
  121. package/esm5/src/di/jit/injectable.js +11 -2
  122. package/esm5/src/di/jit/util.js +6 -5
  123. package/esm5/src/di/r3_injector.js +4 -4
  124. package/esm5/src/i18n/locale_data_api.js +20 -6
  125. package/esm5/src/i18n/locale_en.js +16 -5
  126. package/esm5/src/i18n/localization.js +6 -1
  127. package/esm5/src/i18n/tokens.js +40 -1
  128. package/esm5/src/interface/type.js +1 -1
  129. package/esm5/src/metadata/ng_module.js +1 -1
  130. package/esm5/src/render/api.js +4 -1
  131. package/esm5/src/render3/assert.js +4 -1
  132. package/esm5/src/render3/bindings.js +22 -4
  133. package/esm5/src/render3/component.js +47 -22
  134. package/esm5/src/render3/component_ref.js +15 -17
  135. package/esm5/src/render3/definition.js +3 -1
  136. package/esm5/src/render3/di.js +3 -4
  137. package/esm5/src/render3/di_setup.js +4 -5
  138. package/esm5/src/render3/errors.js +69 -12
  139. package/esm5/src/render3/features/inherit_definition_feature.js +74 -42
  140. package/esm5/src/render3/features/ng_onchanges_feature.js +1 -1
  141. package/esm5/src/render3/global_utils_api.js +3 -3
  142. package/esm5/src/render3/i18n.js +51 -51
  143. package/esm5/src/render3/index.js +2 -2
  144. package/esm5/src/render3/instructions/advance.js +9 -11
  145. package/esm5/src/render3/instructions/all.js +1 -2
  146. package/esm5/src/render3/instructions/attribute.js +9 -5
  147. package/esm5/src/render3/instructions/attribute_interpolation.js +49 -13
  148. package/esm5/src/render3/instructions/change_detection.js +8 -21
  149. package/esm5/src/render3/instructions/class_map_interpolation.js +13 -12
  150. package/esm5/src/render3/instructions/container.js +13 -12
  151. package/esm5/src/render3/instructions/element.js +46 -114
  152. package/esm5/src/render3/instructions/element_container.js +8 -9
  153. package/esm5/src/render3/instructions/embedded_view.js +7 -7
  154. package/esm5/src/render3/instructions/host_property.js +8 -7
  155. package/esm5/src/render3/instructions/listener.js +13 -13
  156. package/esm5/src/render3/instructions/lview_debug.js +56 -15
  157. package/esm5/src/render3/instructions/projection.js +6 -5
  158. package/esm5/src/render3/instructions/property.js +17 -6
  159. package/esm5/src/render3/instructions/property_interpolation.js +32 -24
  160. package/esm5/src/render3/instructions/shared.js +264 -211
  161. package/esm5/src/render3/instructions/storage.js +4 -6
  162. package/esm5/src/render3/instructions/style_prop_interpolation.js +12 -12
  163. package/esm5/src/render3/instructions/styling.js +685 -363
  164. package/esm5/src/render3/instructions/text.js +5 -5
  165. package/esm5/src/render3/interfaces/definition.js +1 -1
  166. package/esm5/src/render3/interfaces/node.js +49 -1
  167. package/esm5/src/render3/interfaces/styling.js +57 -1
  168. package/esm5/src/render3/interfaces/view.js +1 -1
  169. package/esm5/src/render3/jit/directive.js +8 -10
  170. package/esm5/src/render3/jit/environment.js +1 -3
  171. package/esm5/src/render3/node_manipulation.js +167 -54
  172. package/esm5/src/render3/node_selector_matcher.js +113 -20
  173. package/esm5/src/render3/node_util.js +12 -7
  174. package/esm5/src/render3/pipe.js +10 -14
  175. package/esm5/src/render3/pure_function.js +103 -33
  176. package/esm5/src/render3/query.js +25 -24
  177. package/esm5/src/render3/state.js +34 -131
  178. package/esm5/src/render3/styling/class_differ.js +39 -0
  179. package/esm5/src/render3/styling/static_styling.js +42 -0
  180. package/esm5/src/render3/styling/style_binding_list.js +411 -0
  181. package/esm5/src/render3/styling/styling_parser.js +265 -0
  182. package/esm5/src/render3/tokens.js +2 -2
  183. package/esm5/src/render3/util/attrs_utils.js +117 -2
  184. package/esm5/src/render3/util/change_detection_utils.js +23 -0
  185. package/esm5/src/render3/util/discovery_utils.js +115 -99
  186. package/esm5/src/render3/util/global_utils.js +5 -5
  187. package/esm5/src/render3/util/view_utils.js +5 -5
  188. package/esm5/src/render3/view_engine_compatibility.js +37 -39
  189. package/esm5/src/render3/view_ref.js +14 -13
  190. package/esm5/src/sanitization/bypass.js +1 -1
  191. package/esm5/src/sanitization/inert_body.js +20 -13
  192. package/esm5/src/sanitization/sanitization.js +16 -5
  193. package/esm5/src/util/array_utils.js +240 -1
  194. package/esm5/src/util/assert.js +37 -21
  195. package/esm5/src/util/char_code.js +8 -0
  196. package/esm5/src/util/iterable.js +4 -1
  197. package/esm5/src/util/ng_dev_mode.js +1 -12
  198. package/esm5/src/util/stringify.js +14 -1
  199. package/esm5/src/version.js +1 -1
  200. package/esm5/src/view/services.js +1 -1
  201. package/esm5/testing/src/r3_test_bed.js +9 -1
  202. package/esm5/testing/src/r3_test_bed_compiler.js +9 -15
  203. package/esm5/testing/src/styling.js +82 -0
  204. package/fesm2015/core.js +5352 -6012
  205. package/fesm2015/core.js.map +1 -1
  206. package/fesm2015/testing.js +10 -14
  207. package/fesm2015/testing.js.map +1 -1
  208. package/fesm5/core.js +3987 -3980
  209. package/fesm5/core.js.map +1 -1
  210. package/fesm5/testing.js +18 -16
  211. package/fesm5/testing.js.map +1 -1
  212. package/package.json +1 -1
  213. package/schematics/migrations/missing-injectable/transform.js +2 -3
  214. package/schematics/migrations/module-with-providers/transform.js +3 -2
  215. package/schematics/migrations/undecorated-classes-with-di/index.js +2 -2
  216. package/schematics/utils/typescript/compiler_host.js +2 -2
  217. package/src/r3_symbols.d.ts +46 -23
  218. package/testing/testing.d.ts +3 -5
  219. package/testing/testing.metadata.json +1 -1
  220. package/testing.d.ts +2 -2
  221. package/esm2015/global.js +0 -7
  222. package/esm2015/src/render3/instructions/alloc_host_vars.js +0 -80
  223. package/esm2015/src/render3/styling/bindings.js +0 -1248
  224. package/esm2015/src/render3/styling/map_based_bindings.js +0 -384
  225. package/esm2015/src/render3/styling/state.js +0 -135
  226. package/esm2015/src/render3/styling/styling_debug.js +0 -712
  227. package/esm2015/src/render3/util/styling_utils.js +0 -625
  228. package/esm5/global.js +0 -9
  229. package/esm5/src/render3/instructions/alloc_host_vars.js +0 -62
  230. package/esm5/src/render3/styling/bindings.js +0 -949
  231. package/esm5/src/render3/styling/map_based_bindings.js +0 -310
  232. package/esm5/src/render3/styling/state.js +0 -56
  233. package/esm5/src/render3/styling/styling_debug.js +0 -352
  234. package/esm5/src/render3/util/styling_utils.js +0 -378
@@ -1,384 +0,0 @@
1
- /**
2
- * @fileoverview added by tsickle
3
- * Generated from: packages/core/src/render3/styling/map_based_bindings.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 { getBindingValue, getMapProp, getMapValue, getValue, getValuesCount, isStylingValueDefined } from '../util/styling_utils';
15
- import { setStylingMapsSyncFn } from './bindings';
16
- /**
17
- * --------
18
- *
19
- * This file contains the algorithm logic for applying map-based bindings
20
- * such as `[style]` and `[class]`.
21
- *
22
- * --------
23
- */
24
- /**
25
- * Enables support for map-based styling bindings (e.g. `[style]` and `[class]` bindings).
26
- * @return {?}
27
- */
28
- export function activateStylingMapFeature() {
29
- setStylingMapsSyncFn(syncStylingMap);
30
- }
31
- /**
32
- * Used to apply styling values presently within any map-based bindings on an element.
33
- *
34
- * Angular supports map-based styling bindings which can be applied via the
35
- * `[style]` and `[class]` bindings which can be placed on any HTML element.
36
- * These bindings can work independently, together or alongside prop-based
37
- * styling bindings (e.g. `<div [style]="x" [style.width]="w">`).
38
- *
39
- * If a map-based styling binding is detected by the compiler, the following
40
- * AOT code is produced:
41
- *
42
- * ```typescript
43
- * styleMap(ctx.styles); // styles = {key:value}
44
- * classMap(ctx.classes); // classes = {key:value}|string
45
- * ```
46
- *
47
- * If and when either of the instructions above are evaluated, then the code
48
- * present in this file is included into the bundle. The mechanism used, to
49
- * activate support for map-based bindings at runtime is possible via the
50
- * `activeStylingMapFeature` function (which is also present in this file).
51
- *
52
- * # The Algorithm
53
- * Whenever a map-based binding updates (which is when the identity of the
54
- * map-value changes) then the map is iterated over and a `StylingMapArray` array
55
- * is produced. The `StylingMapArray` instance is stored in the binding location
56
- * where the `BINDING_INDEX` is situated when the `styleMap()` or `classMap()`
57
- * instruction were called. Once the binding changes, then the internal `bitMask`
58
- * value is marked as dirty.
59
- *
60
- * Styling values are applied once CD exits the element (which happens when
61
- * the `advance(n)` instruction is called or the template function exits). When
62
- * this occurs, all prop-based bindings are applied. If a map-based binding is
63
- * present then a special flushing function (called a sync function) is made
64
- * available and it will be called each time a styling property is flushed.
65
- *
66
- * The flushing algorithm is designed to apply styling for a property (which is
67
- * a CSS property or a className value) one by one. If map-based bindings
68
- * are present, then the flushing algorithm will keep calling the maps styling
69
- * sync function each time a property is visited. This way, the flushing
70
- * behavior of map-based bindings will always be at the same property level
71
- * as the current prop-based property being iterated over (because everything
72
- * is alphabetically sorted).
73
- *
74
- * Let's imagine we have the following HTML template code:
75
- *
76
- * ```html
77
- * <div [style]="{width:'100px', height:'200px', 'z-index':'10'}"
78
- * [style.width.px]="200">...</div>
79
- * ```
80
- *
81
- * When CD occurs, both the `[style]` and `[style.width]` bindings
82
- * are evaluated. Then when the styles are flushed on screen, the
83
- * following operations happen:
84
- *
85
- * 1. `[style.width]` is attempted to be written to the element.
86
- *
87
- * 2. Once that happens, the algorithm instructs the map-based
88
- * entries (`[style]` in this case) to "catch up" and apply
89
- * all values up to the `width` value. When this happens the
90
- * `height` value is applied to the element (since it is
91
- * alphabetically situated before the `width` property).
92
- *
93
- * 3. Since there are no more prop-based entries anymore, the
94
- * loop exits and then, just before the flushing ends, it
95
- * instructs all map-based bindings to "finish up" applying
96
- * their values.
97
- *
98
- * 4. The only remaining value within the map-based entries is
99
- * the `z-index` value (`width` got skipped because it was
100
- * successfully applied via the prop-based `[style.width]`
101
- * binding). Since all map-based entries are told to "finish up",
102
- * the `z-index` value is iterated over and it is then applied
103
- * to the element.
104
- *
105
- * The most important thing to take note of here is that prop-based
106
- * bindings are evaluated in order alongside map-based bindings.
107
- * This allows all styling across an element to be applied in O(n)
108
- * time (a similar algorithm is that of the array merge algorithm
109
- * in merge sort).
110
- * @type {?}
111
- */
112
- export const syncStylingMap = (/**
113
- * @param {?} context
114
- * @param {?} renderer
115
- * @param {?} element
116
- * @param {?} data
117
- * @param {?} sourceIndex
118
- * @param {?} applyStylingFn
119
- * @param {?} sanitizer
120
- * @param {?} mode
121
- * @param {?=} targetProp
122
- * @param {?=} defaultValue
123
- * @return {?}
124
- */
125
- (context, renderer, element, data, sourceIndex, applyStylingFn, sanitizer, mode, targetProp, defaultValue) => {
126
- /** @type {?} */
127
- let targetPropValueWasApplied = false;
128
- // once the map-based styling code is activate it is never deactivated. For this reason a
129
- // check to see if the current styling context has any map based bindings is required.
130
- /** @type {?} */
131
- const totalMaps = getValuesCount(context);
132
- if (totalMaps) {
133
- /** @type {?} */
134
- let runTheSyncAlgorithm = true;
135
- /** @type {?} */
136
- const loopUntilEnd = !targetProp;
137
- // If the code is told to finish up (run until the end), but the mode
138
- // hasn't been flagged to apply values (it only traverses values) then
139
- // there is no point in iterating over the array because nothing will
140
- // be applied to the element.
141
- if (loopUntilEnd && (mode & 1 /* ApplyAllValues */) === 0) {
142
- runTheSyncAlgorithm = false;
143
- targetPropValueWasApplied = true;
144
- }
145
- if (runTheSyncAlgorithm) {
146
- targetPropValueWasApplied = innerSyncStylingMap(context, renderer, element, data, applyStylingFn, sanitizer, mode, targetProp || null, sourceIndex, defaultValue || null);
147
- }
148
- if (loopUntilEnd) {
149
- resetSyncCursors();
150
- }
151
- }
152
- return targetPropValueWasApplied;
153
- });
154
- /**
155
- * Recursive function designed to apply map-based styling to an element one map at a time.
156
- *
157
- * This function is designed to be called from the `syncStylingMap` function and will
158
- * apply map-based styling data one map at a time to the provided `element`.
159
- *
160
- * This function is recursive and it will call itself if a follow-up map value is to be
161
- * processed. To learn more about how the algorithm works, see `syncStylingMap`.
162
- * @param {?} context
163
- * @param {?} renderer
164
- * @param {?} element
165
- * @param {?} data
166
- * @param {?} applyStylingFn
167
- * @param {?} sanitizer
168
- * @param {?} mode
169
- * @param {?} targetProp
170
- * @param {?} currentMapIndex
171
- * @param {?} defaultValue
172
- * @return {?}
173
- */
174
- function innerSyncStylingMap(context, renderer, element, data, applyStylingFn, sanitizer, mode, targetProp, currentMapIndex, defaultValue) {
175
- /** @type {?} */
176
- const totalMaps = getValuesCount(context) - 1;
177
- // maps have no default value
178
- /** @type {?} */
179
- const mapsLimit = totalMaps - 1;
180
- /** @type {?} */
181
- const recurseInnerMaps = currentMapIndex < mapsLimit && (mode & 8 /* RecurseInnerMaps */) !== 0;
182
- /** @type {?} */
183
- const checkValuesOnly = (mode & 16 /* CheckValuesOnly */) !== 0;
184
- if (checkValuesOnly) {
185
- // inner modes do not check values ever (that can only happen
186
- // when sourceIndex === 0)
187
- mode &= ~16 /* CheckValuesOnly */;
188
- }
189
- /** @type {?} */
190
- let targetPropValueWasApplied = false;
191
- if (currentMapIndex <= mapsLimit) {
192
- /** @type {?} */
193
- let cursor = getCurrentSyncCursor(currentMapIndex);
194
- /** @type {?} */
195
- const bindingIndex = (/** @type {?} */ (getBindingValue(context, 2 /* ValuesStartPosition */, currentMapIndex)));
196
- /** @type {?} */
197
- const stylingMapArr = getValue(data, bindingIndex);
198
- if (stylingMapArr) {
199
- while (cursor < stylingMapArr.length) {
200
- /** @type {?} */
201
- const prop = getMapProp(stylingMapArr, cursor);
202
- /** @type {?} */
203
- const iteratedTooFar = targetProp && prop > targetProp;
204
- /** @type {?} */
205
- const isTargetPropMatched = !iteratedTooFar && prop === targetProp;
206
- /** @type {?} */
207
- const value = getMapValue(stylingMapArr, cursor);
208
- /** @type {?} */
209
- const valueIsDefined = isStylingValueDefined(value);
210
- // the recursive code is designed to keep applying until
211
- // it reaches or goes past the target prop. If and when
212
- // this happens then it will stop processing values, but
213
- // all other map values must also catch up to the same
214
- // point. This is why a recursive call is still issued
215
- // even if the code has iterated too far.
216
- /** @type {?} */
217
- const innerMode = iteratedTooFar ? mode : resolveInnerMapMode(mode, valueIsDefined, isTargetPropMatched);
218
- /** @type {?} */
219
- const innerProp = iteratedTooFar ? targetProp : prop;
220
- /** @type {?} */
221
- let valueApplied = recurseInnerMaps ?
222
- innerSyncStylingMap(context, renderer, element, data, applyStylingFn, sanitizer, innerMode, innerProp, currentMapIndex + 1, defaultValue) :
223
- false;
224
- if (iteratedTooFar) {
225
- if (!targetPropValueWasApplied) {
226
- targetPropValueWasApplied = valueApplied;
227
- }
228
- break;
229
- }
230
- if (!valueApplied && isValueAllowedToBeApplied(mode, isTargetPropMatched)) {
231
- valueApplied = true;
232
- if (!checkValuesOnly) {
233
- /** @type {?} */
234
- const useDefault = isTargetPropMatched && !valueIsDefined;
235
- /** @type {?} */
236
- const bindingIndexToApply = isTargetPropMatched ? bindingIndex : null;
237
- /** @type {?} */
238
- let finalValue;
239
- if (useDefault) {
240
- finalValue = defaultValue;
241
- }
242
- else {
243
- finalValue = sanitizer ?
244
- sanitizer(prop, value, 3 /* ValidateAndSanitize */) :
245
- (value ? unwrapSafeValue(value) : null);
246
- }
247
- applyStylingFn(renderer, element, prop, finalValue, bindingIndexToApply);
248
- }
249
- }
250
- targetPropValueWasApplied = valueApplied && isTargetPropMatched;
251
- cursor += 2 /* TupleSize */;
252
- }
253
- setCurrentSyncCursor(currentMapIndex, cursor);
254
- // this is a fallback case in the event that the styling map is `null` for this
255
- // binding but there are other map-based bindings that need to be evaluated
256
- // afterwards. If the `prop` value is falsy then the intention is to cycle
257
- // through all of the properties in the remaining maps as well. If the current
258
- // styling map is too short then there are no values to iterate over. In either
259
- // case the follow-up maps need to be iterated over.
260
- if (recurseInnerMaps &&
261
- (stylingMapArr.length === 1 /* ValuesStartPosition */ || !targetProp)) {
262
- targetPropValueWasApplied = innerSyncStylingMap(context, renderer, element, data, applyStylingFn, sanitizer, mode, targetProp, currentMapIndex + 1, defaultValue);
263
- }
264
- }
265
- else if (recurseInnerMaps) {
266
- targetPropValueWasApplied = innerSyncStylingMap(context, renderer, element, data, applyStylingFn, sanitizer, mode, targetProp, currentMapIndex + 1, defaultValue);
267
- }
268
- }
269
- return targetPropValueWasApplied;
270
- }
271
- /**
272
- * Used to determine the mode for the inner recursive call.
273
- *
274
- * If an inner map is iterated on then this is done so for one
275
- * of two reasons:
276
- *
277
- * - value is being applied:
278
- * if the value is being applied from this current styling
279
- * map then there is no need to apply it in a deeper map
280
- * (i.e. the `SkipTargetProp` flag is set)
281
- *
282
- * - value is being not applied:
283
- * apply the value if it is found in a deeper map.
284
- * (i.e. the `SkipTargetProp` flag is unset)
285
- *
286
- * When these reasons are encountered the flags will for the
287
- * inner map mode will be configured.
288
- * @param {?} currentMode
289
- * @param {?} valueIsDefined
290
- * @param {?} isTargetPropMatched
291
- * @return {?}
292
- */
293
- function resolveInnerMapMode(currentMode, valueIsDefined, isTargetPropMatched) {
294
- /** @type {?} */
295
- let innerMode = currentMode;
296
- // the statements below figures out whether or not an inner styling map
297
- // is allowed to apply its value or not. The main thing to keep note
298
- // of is that if the target prop isn't matched then its expected that
299
- // all values before it are allowed to be applied so long as "apply all values"
300
- // is set to true.
301
- /** @type {?} */
302
- const applyAllValues = currentMode & 1 /* ApplyAllValues */;
303
- /** @type {?} */
304
- const applyTargetProp = currentMode & 2 /* ApplyTargetProp */;
305
- /** @type {?} */
306
- const allowInnerApply = !valueIsDefined && (isTargetPropMatched ? applyTargetProp : applyAllValues);
307
- if (allowInnerApply) {
308
- // case 1: set the mode to apply the targeted prop value if it
309
- // ends up being encountered in another map value
310
- innerMode |= 2 /* ApplyTargetProp */;
311
- innerMode &= ~4 /* SkipTargetProp */;
312
- }
313
- else {
314
- // case 2: set the mode to skip the targeted prop value if it
315
- // ends up being encountered in another map value
316
- innerMode |= 4 /* SkipTargetProp */;
317
- innerMode &= ~2 /* ApplyTargetProp */;
318
- }
319
- return innerMode;
320
- }
321
- /**
322
- * Decides whether or not a prop/value entry will be applied to an element.
323
- *
324
- * To determine whether or not a value is to be applied,
325
- * the following procedure is evaluated:
326
- *
327
- * First check to see the current `mode` status:
328
- * 1. If the mode value permits all props to be applied then allow.
329
- * - But do not allow if the current prop is set to be skipped.
330
- * 2. Otherwise if the current prop is permitted then allow.
331
- * @param {?} mode
332
- * @param {?} isTargetPropMatched
333
- * @return {?}
334
- */
335
- function isValueAllowedToBeApplied(mode, isTargetPropMatched) {
336
- /** @type {?} */
337
- let doApplyValue = (mode & 1 /* ApplyAllValues */) !== 0;
338
- if (!doApplyValue) {
339
- if (mode & 2 /* ApplyTargetProp */) {
340
- doApplyValue = isTargetPropMatched;
341
- }
342
- }
343
- else if ((mode & 4 /* SkipTargetProp */) && isTargetPropMatched) {
344
- doApplyValue = false;
345
- }
346
- return doApplyValue;
347
- }
348
- /**
349
- * Used to keep track of concurrent cursor values for multiple map-based styling bindings present on
350
- * an element.
351
- * @type {?}
352
- */
353
- const MAP_CURSORS = [];
354
- /**
355
- * Used to reset the state of each cursor value being used to iterate over map-based styling
356
- * bindings.
357
- * @return {?}
358
- */
359
- function resetSyncCursors() {
360
- for (let i = 0; i < MAP_CURSORS.length; i++) {
361
- MAP_CURSORS[i] = 1 /* ValuesStartPosition */;
362
- }
363
- }
364
- /**
365
- * Returns an active cursor value at a given mapIndex location.
366
- * @param {?} mapIndex
367
- * @return {?}
368
- */
369
- function getCurrentSyncCursor(mapIndex) {
370
- if (mapIndex >= MAP_CURSORS.length) {
371
- MAP_CURSORS.push(1 /* ValuesStartPosition */);
372
- }
373
- return MAP_CURSORS[mapIndex];
374
- }
375
- /**
376
- * Sets a cursor value at a given mapIndex location.
377
- * @param {?} mapIndex
378
- * @param {?} indexValue
379
- * @return {?}
380
- */
381
- function setCurrentSyncCursor(mapIndex, indexValue) {
382
- MAP_CURSORS[mapIndex] = indexValue;
383
- }
384
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map_based_bindings.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/styling/map_based_bindings.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n* @license\n* Copyright Google Inc. All Rights Reserved.\n*\n* Use of this source code is governed by an MIT-style license that can be\n* found in the LICENSE file at https://angular.io/license\n*/\nimport {unwrapSafeValue} from '../../sanitization/bypass';\nimport {StyleSanitizeFn, StyleSanitizeMode} from '../../sanitization/style_sanitizer';\nimport {ProceduralRenderer3, RElement, Renderer3} from '../interfaces/renderer';\nimport {ApplyStylingFn, LStylingData, StylingMapArray, StylingMapArrayIndex, StylingMapsSyncMode, SyncStylingMapsFn, TStylingContext, TStylingContextIndex} from '../interfaces/styling';\nimport {getBindingValue, getMapProp, getMapValue, getValue, getValuesCount, isStylingValueDefined} from '../util/styling_utils';\n\nimport {setStylingMapsSyncFn} from './bindings';\n\n\n/**\n * --------\n *\n * This file contains the algorithm logic for applying map-based bindings\n * such as `[style]` and `[class]`.\n *\n * --------\n */\n\n/**\n * Enables support for map-based styling bindings (e.g. `[style]` and `[class]` bindings).\n */\nexport function activateStylingMapFeature() {\n  setStylingMapsSyncFn(syncStylingMap);\n}\n\n/**\n * Used to apply styling values presently within any map-based bindings on an element.\n *\n * Angular supports map-based styling bindings which can be applied via the\n * `[style]` and `[class]` bindings which can be placed on any HTML element.\n * These bindings can work independently, together or alongside prop-based\n * styling bindings (e.g. `<div [style]=\"x\" [style.width]=\"w\">`).\n *\n * If a map-based styling binding is detected by the compiler, the following\n * AOT code is produced:\n *\n * ```typescript\n * styleMap(ctx.styles); // styles = {key:value}\n * classMap(ctx.classes); // classes = {key:value}|string\n * ```\n *\n * If and when either of the instructions above are evaluated, then the code\n * present in this file is included into the bundle. The mechanism used, to\n * activate support for map-based bindings at runtime is possible via the\n * `activeStylingMapFeature` function (which is also present in this file).\n *\n * # The Algorithm\n * Whenever a map-based binding updates (which is when the identity of the\n * map-value changes) then the map is iterated over and a `StylingMapArray` array\n * is produced. The `StylingMapArray` instance is stored in the binding location\n * where the `BINDING_INDEX` is situated when the `styleMap()` or `classMap()`\n * instruction were called. Once the binding changes, then the internal `bitMask`\n * value is marked as dirty.\n *\n * Styling values are applied once CD exits the element (which happens when\n * the `advance(n)` instruction is called or the template function exits). When\n * this occurs, all prop-based bindings are applied. If a map-based binding is\n * present then a special flushing function (called a sync function) is made\n * available and it will be called each time a styling property is flushed.\n *\n * The flushing algorithm is designed to apply styling for a property (which is\n * a CSS property or a className value) one by one. If map-based bindings\n * are present, then the flushing algorithm will keep calling the maps styling\n * sync function each time a property is visited. This way, the flushing\n * behavior of map-based bindings will always be at the same property level\n * as the current prop-based property being iterated over (because everything\n * is alphabetically sorted).\n *\n * Let's imagine we have the following HTML template code:\n *\n * ```html\n * <div [style]=\"{width:'100px', height:'200px', 'z-index':'10'}\"\n *      [style.width.px]=\"200\">...</div>\n * ```\n *\n * When CD occurs, both the `[style]` and `[style.width]` bindings\n * are evaluated. Then when the styles are flushed on screen, the\n * following operations happen:\n *\n * 1. `[style.width]` is attempted to be written to the element.\n *\n * 2.  Once that happens, the algorithm instructs the map-based\n *     entries (`[style]` in this case) to \"catch up\" and apply\n *     all values up to the `width` value. When this happens the\n *     `height` value is applied to the element (since it is\n *     alphabetically situated before the `width` property).\n *\n * 3. Since there are no more prop-based entries anymore, the\n *    loop exits and then, just before the flushing ends, it\n *    instructs all map-based bindings to \"finish up\" applying\n *    their values.\n *\n * 4. The only remaining value within the map-based entries is\n *    the `z-index` value (`width` got skipped because it was\n *    successfully applied via the prop-based `[style.width]`\n *    binding). Since all map-based entries are told to \"finish up\",\n *    the `z-index` value is iterated over and it is then applied\n *    to the element.\n *\n * The most important thing to take note of here is that prop-based\n * bindings are evaluated in order alongside map-based bindings.\n * This allows all styling across an element to be applied in O(n)\n * time (a similar algorithm is that of the array merge algorithm\n * in merge sort).\n */\nexport const syncStylingMap: SyncStylingMapsFn =\n    (context: TStylingContext, renderer: Renderer3 | ProceduralRenderer3 | null, element: RElement,\n     data: LStylingData, sourceIndex: number, applyStylingFn: ApplyStylingFn,\n     sanitizer: StyleSanitizeFn | null, mode: StylingMapsSyncMode, targetProp?: string | null,\n     defaultValue?: string | boolean | null): boolean => {\n      let targetPropValueWasApplied = false;\n\n      // once the map-based styling code is activate it is never deactivated. For this reason a\n      // check to see if the current styling context has any map based bindings is required.\n      const totalMaps = getValuesCount(context);\n      if (totalMaps) {\n        let runTheSyncAlgorithm = true;\n        const loopUntilEnd = !targetProp;\n\n        // If the code is told to finish up (run until the end), but the mode\n        // hasn't been flagged to apply values (it only traverses values) then\n        // there is no point in iterating over the array because nothing will\n        // be applied to the element.\n        if (loopUntilEnd && (mode & StylingMapsSyncMode.ApplyAllValues) === 0) {\n          runTheSyncAlgorithm = false;\n          targetPropValueWasApplied = true;\n        }\n\n        if (runTheSyncAlgorithm) {\n          targetPropValueWasApplied = innerSyncStylingMap(\n              context, renderer, element, data, applyStylingFn, sanitizer, mode, targetProp || null,\n              sourceIndex, defaultValue || null);\n        }\n\n        if (loopUntilEnd) {\n          resetSyncCursors();\n        }\n      }\n\n      return targetPropValueWasApplied;\n    };\n\n/**\n * Recursive function designed to apply map-based styling to an element one map at a time.\n *\n * This function is designed to be called from the `syncStylingMap` function and will\n * apply map-based styling data one map at a time to the provided `element`.\n *\n * This function is recursive and it will call itself if a follow-up map value is to be\n * processed. To learn more about how the algorithm works, see `syncStylingMap`.\n */\nfunction innerSyncStylingMap(\n    context: TStylingContext, renderer: Renderer3 | ProceduralRenderer3 | null, element: RElement,\n    data: LStylingData, applyStylingFn: ApplyStylingFn, sanitizer: StyleSanitizeFn | null,\n    mode: StylingMapsSyncMode, targetProp: string | null, currentMapIndex: number,\n    defaultValue: string | boolean | null): boolean {\n  const totalMaps = getValuesCount(context) - 1;  // maps have no default value\n  const mapsLimit = totalMaps - 1;\n  const recurseInnerMaps =\n      currentMapIndex < mapsLimit && (mode & StylingMapsSyncMode.RecurseInnerMaps) !== 0;\n  const checkValuesOnly = (mode & StylingMapsSyncMode.CheckValuesOnly) !== 0;\n\n  if (checkValuesOnly) {\n    // inner modes do not check values ever (that can only happen\n    // when sourceIndex === 0)\n    mode &= ~StylingMapsSyncMode.CheckValuesOnly;\n  }\n\n  let targetPropValueWasApplied = false;\n  if (currentMapIndex <= mapsLimit) {\n    let cursor = getCurrentSyncCursor(currentMapIndex);\n    const bindingIndex = getBindingValue(\n        context, TStylingContextIndex.ValuesStartPosition, currentMapIndex) as number;\n    const stylingMapArr = getValue<StylingMapArray>(data, bindingIndex);\n\n    if (stylingMapArr) {\n      while (cursor < stylingMapArr.length) {\n        const prop = getMapProp(stylingMapArr, cursor);\n        const iteratedTooFar = targetProp && prop > targetProp;\n        const isTargetPropMatched = !iteratedTooFar && prop === targetProp;\n        const value = getMapValue(stylingMapArr, cursor);\n        const valueIsDefined = isStylingValueDefined(value);\n\n        // the recursive code is designed to keep applying until\n        // it reaches or goes past the target prop. If and when\n        // this happens then it will stop processing values, but\n        // all other map values must also catch up to the same\n        // point. This is why a recursive call is still issued\n        // even if the code has iterated too far.\n        const innerMode =\n            iteratedTooFar ? mode : resolveInnerMapMode(mode, valueIsDefined, isTargetPropMatched);\n\n        const innerProp = iteratedTooFar ? targetProp : prop;\n        let valueApplied = recurseInnerMaps ?\n            innerSyncStylingMap(\n                context, renderer, element, data, applyStylingFn, sanitizer, innerMode, innerProp,\n                currentMapIndex + 1, defaultValue) :\n            false;\n\n        if (iteratedTooFar) {\n          if (!targetPropValueWasApplied) {\n            targetPropValueWasApplied = valueApplied;\n          }\n          break;\n        }\n\n        if (!valueApplied && isValueAllowedToBeApplied(mode, isTargetPropMatched)) {\n          valueApplied = true;\n\n          if (!checkValuesOnly) {\n            const useDefault = isTargetPropMatched && !valueIsDefined;\n            const bindingIndexToApply = isTargetPropMatched ? bindingIndex : null;\n\n            let finalValue: any;\n            if (useDefault) {\n              finalValue = defaultValue;\n            } else {\n              finalValue = sanitizer ?\n                  sanitizer(prop, value, StyleSanitizeMode.ValidateAndSanitize) :\n                  (value ? unwrapSafeValue(value) : null);\n            }\n\n            applyStylingFn(renderer, element, prop, finalValue, bindingIndexToApply);\n          }\n        }\n\n        targetPropValueWasApplied = valueApplied && isTargetPropMatched;\n        cursor += StylingMapArrayIndex.TupleSize;\n      }\n      setCurrentSyncCursor(currentMapIndex, cursor);\n\n      // this is a fallback case in the event that the styling map is `null` for this\n      // binding but there are other map-based bindings that need to be evaluated\n      // afterwards. If the `prop` value is falsy then the intention is to cycle\n      // through all of the properties in the remaining maps as well. If the current\n      // styling map is too short then there are no values to iterate over. In either\n      // case the follow-up maps need to be iterated over.\n      if (recurseInnerMaps &&\n          (stylingMapArr.length === StylingMapArrayIndex.ValuesStartPosition || !targetProp)) {\n        targetPropValueWasApplied = innerSyncStylingMap(\n            context, renderer, element, data, applyStylingFn, sanitizer, mode, targetProp,\n            currentMapIndex + 1, defaultValue);\n      }\n    } else if (recurseInnerMaps) {\n      targetPropValueWasApplied = innerSyncStylingMap(\n          context, renderer, element, data, applyStylingFn, sanitizer, mode, targetProp,\n          currentMapIndex + 1, defaultValue);\n    }\n  }\n\n  return targetPropValueWasApplied;\n}\n\n/**\n * Used to determine the mode for the inner recursive call.\n *\n * If an inner map is iterated on then this is done so for one\n * of two reasons:\n *\n * - value is being applied:\n *   if the value is being applied from this current styling\n *   map then there is no need to apply it in a deeper map\n *   (i.e. the `SkipTargetProp` flag is set)\n *\n * - value is being not applied:\n *   apply the value if it is found in a deeper map.\n *   (i.e. the `SkipTargetProp` flag is unset)\n *\n * When these reasons are encountered the flags will for the\n * inner map mode will be configured.\n */\nfunction resolveInnerMapMode(\n    currentMode: number, valueIsDefined: boolean, isTargetPropMatched: boolean): number {\n  let innerMode = currentMode;\n\n  // the statements below figures out whether or not an inner styling map\n  // is allowed to apply its value or not. The main thing to keep note\n  // of is that if the target prop isn't matched then its expected that\n  // all values before it are allowed to be applied so long as \"apply all values\"\n  // is set to true.\n  const applyAllValues = currentMode & StylingMapsSyncMode.ApplyAllValues;\n  const applyTargetProp = currentMode & StylingMapsSyncMode.ApplyTargetProp;\n  const allowInnerApply =\n      !valueIsDefined && (isTargetPropMatched ? applyTargetProp : applyAllValues);\n\n  if (allowInnerApply) {\n    // case 1: set the mode to apply the targeted prop value if it\n    // ends up being encountered in another map value\n    innerMode |= StylingMapsSyncMode.ApplyTargetProp;\n    innerMode &= ~StylingMapsSyncMode.SkipTargetProp;\n  } else {\n    // case 2: set the mode to skip the targeted prop value if it\n    // ends up being encountered in another map value\n    innerMode |= StylingMapsSyncMode.SkipTargetProp;\n    innerMode &= ~StylingMapsSyncMode.ApplyTargetProp;\n  }\n\n  return innerMode;\n}\n\n/**\n * Decides whether or not a prop/value entry will be applied to an element.\n *\n * To determine whether or not a value is to be applied,\n * the following procedure is evaluated:\n *\n * First check to see the current `mode` status:\n *  1. If the mode value permits all props to be applied then allow.\n *    - But do not allow if the current prop is set to be skipped.\n *  2. Otherwise if the current prop is permitted then allow.\n */\nfunction isValueAllowedToBeApplied(mode: StylingMapsSyncMode, isTargetPropMatched: boolean) {\n  let doApplyValue = (mode & StylingMapsSyncMode.ApplyAllValues) !== 0;\n  if (!doApplyValue) {\n    if (mode & StylingMapsSyncMode.ApplyTargetProp) {\n      doApplyValue = isTargetPropMatched;\n    }\n  } else if ((mode & StylingMapsSyncMode.SkipTargetProp) && isTargetPropMatched) {\n    doApplyValue = false;\n  }\n  return doApplyValue;\n}\n\n/**\n * Used to keep track of concurrent cursor values for multiple map-based styling bindings present on\n * an element.\n */\nconst MAP_CURSORS: number[] = [];\n\n/**\n * Used to reset the state of each cursor value being used to iterate over map-based styling\n * bindings.\n */\nfunction resetSyncCursors() {\n  for (let i = 0; i < MAP_CURSORS.length; i++) {\n    MAP_CURSORS[i] = StylingMapArrayIndex.ValuesStartPosition;\n  }\n}\n\n/**\n * Returns an active cursor value at a given mapIndex location.\n */\nfunction getCurrentSyncCursor(mapIndex: number) {\n  if (mapIndex >= MAP_CURSORS.length) {\n    MAP_CURSORS.push(StylingMapArrayIndex.ValuesStartPosition);\n  }\n  return MAP_CURSORS[mapIndex];\n}\n\n/**\n * Sets a cursor value at a given mapIndex location.\n */\nfunction setCurrentSyncCursor(mapIndex: number, indexValue: number) {\n  MAP_CURSORS[mapIndex] = indexValue;\n}\n"]}
@@ -1,135 +0,0 @@
1
- /**
2
- * @fileoverview added by tsickle
3
- * Generated from: packages/core/src/render3/styling/state.ts
4
- * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
5
- */
6
- import { TEMPLATE_DIRECTIVE_INDEX } from '../util/styling_utils';
7
- /**
8
- * Used as a state reference for update values between style/class binding instructions.
9
- *
10
- * In addition to storing the element and bit-mask related values, the state also
11
- * stores the `sourceIndex` value. The `sourceIndex` value is an incremented value
12
- * that identifies what "source" (i.e. the template, a specific directive by index or
13
- * component) is currently applying its styling bindings to the element.
14
- * @record
15
- */
16
- export function StylingState() { }
17
- if (false) {
18
- /**
19
- * The element that is currently being processed
20
- * @type {?}
21
- */
22
- StylingState.prototype.element;
23
- /**
24
- * The directive index that is currently active (`0` === template)
25
- * @type {?}
26
- */
27
- StylingState.prototype.directiveIndex;
28
- /**
29
- * The source (column) index that is currently active (`0` === template)
30
- * @type {?}
31
- */
32
- StylingState.prototype.sourceIndex;
33
- /**
34
- * The classes update bit mask value that is processed during each class binding
35
- * @type {?}
36
- */
37
- StylingState.prototype.classesBitMask;
38
- /**
39
- * The classes update bit index value that is processed during each class binding
40
- * @type {?}
41
- */
42
- StylingState.prototype.classesIndex;
43
- /**
44
- * The styles update bit mask value that is processed during each style binding
45
- * @type {?}
46
- */
47
- StylingState.prototype.stylesBitMask;
48
- /**
49
- * The styles update bit index value that is processed during each style binding
50
- * @type {?}
51
- */
52
- StylingState.prototype.stylesIndex;
53
- /**
54
- * The last class map that was applied (i.e. `[class]="x"`).
55
- *
56
- * Note that this property is only populated when direct class values are applied
57
- * (i.e. context resolution is not used).
58
- *
59
- * See `allowDirectStyling` for more info.
60
- * @type {?}
61
- */
62
- StylingState.prototype.lastDirectClassMap;
63
- /**
64
- * The last style map that was applied (i.e. `[style]="x"`)
65
- *
66
- * Note that this property is only populated when direct style values are applied
67
- * (i.e. context resolution is not used).
68
- *
69
- * See `allowDirectStyling` for more info.
70
- * @type {?}
71
- */
72
- StylingState.prototype.lastDirectStyleMap;
73
- }
74
- // these values will get filled in the very first time this is accessed...
75
- /** @type {?} */
76
- const _state = {
77
- element: null,
78
- directiveIndex: -1,
79
- sourceIndex: -1,
80
- classesBitMask: -1,
81
- classesIndex: -1,
82
- stylesBitMask: -1,
83
- stylesIndex: -1,
84
- lastDirectClassMap: null,
85
- lastDirectStyleMap: null,
86
- };
87
- /** @type {?} */
88
- const BIT_MASK_START_VALUE = 0;
89
- // the `0` start value is reserved for [map]-based entries
90
- /** @type {?} */
91
- const INDEX_START_VALUE = 1;
92
- /**
93
- * Returns (or instantiates) the styling state for the given element.
94
- *
95
- * Styling state is accessed and processed each time a style or class binding
96
- * is evaluated.
97
- *
98
- * If and when the provided `element` doesn't match the current element in the
99
- * state then this means that styling was recently cleared or the element has
100
- * changed in change detection. In both cases the styling state is fully reset.
101
- *
102
- * If and when the provided `directiveIndex` doesn't match the current directive
103
- * index in the state then this means that a new source has introduced itself into
104
- * the styling code (or, in other words, another directive or component has started
105
- * to apply its styling host bindings to the element).
106
- * @param {?} element
107
- * @param {?} directiveIndex
108
- * @return {?}
109
- */
110
- export function getStylingState(element, directiveIndex) {
111
- if (_state.element !== element) {
112
- _state.element = element;
113
- _state.directiveIndex = directiveIndex;
114
- _state.sourceIndex = directiveIndex === TEMPLATE_DIRECTIVE_INDEX ? 0 : 1;
115
- _state.classesBitMask = BIT_MASK_START_VALUE;
116
- _state.classesIndex = INDEX_START_VALUE;
117
- _state.stylesBitMask = BIT_MASK_START_VALUE;
118
- _state.stylesIndex = INDEX_START_VALUE;
119
- _state.lastDirectClassMap = null;
120
- _state.lastDirectStyleMap = null;
121
- }
122
- else if (_state.directiveIndex !== directiveIndex) {
123
- _state.directiveIndex = directiveIndex;
124
- _state.sourceIndex++;
125
- }
126
- return _state;
127
- }
128
- /**
129
- * Clears the styling state so that it can be used by another element's styling code.
130
- * @return {?}
131
- */
132
- export function resetStylingState() {
133
- _state.element = null;
134
- }
135
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"state.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/styling/state.ts"],"names":[],"mappings":";;;;;AASA,OAAO,EAAC,wBAAwB,EAAC,MAAM,uBAAuB,CAAC;;;;;;;;;;AA8B/D,kCAyCC;;;;;;IAvCC,+BAAuB;;;;;IAGvB,sCAAuB;;;;;IAGvB,mCAAoB;;;;;IAGpB,sCAAuB;;;;;IAGvB,oCAAqB;;;;;IAGrB,qCAAsB;;;;;IAGtB,mCAAoB;;;;;;;;;;IAUpB,0CAAyC;;;;;;;;;;IAUzC,0CAAyC;;;;MAIrC,MAAM,GAAiB;IAC3B,OAAO,EAAE,IAAI;IACb,cAAc,EAAE,CAAC,CAAC;IAClB,WAAW,EAAE,CAAC,CAAC;IACf,cAAc,EAAE,CAAC,CAAC;IAClB,YAAY,EAAE,CAAC,CAAC;IAChB,aAAa,EAAE,CAAC,CAAC;IACjB,WAAW,EAAE,CAAC,CAAC;IACf,kBAAkB,EAAE,IAAI;IACxB,kBAAkB,EAAE,IAAI;CACzB;;MAEK,oBAAoB,GAAG,CAAC;;;MAGxB,iBAAiB,GAAG,CAAC;;;;;;;;;;;;;;;;;;;AAiB3B,MAAM,UAAU,eAAe,CAAC,OAAiB,EAAE,cAAsB;IACvE,IAAI,MAAM,CAAC,OAAO,KAAK,OAAO,EAAE;QAC9B,MAAM,CAAC,OAAO,GAAG,OAAO,CAAC;QACzB,MAAM,CAAC,cAAc,GAAG,cAAc,CAAC;QACvC,MAAM,CAAC,WAAW,GAAG,cAAc,KAAK,wBAAwB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACzE,MAAM,CAAC,cAAc,GAAG,oBAAoB,CAAC;QAC7C,MAAM,CAAC,YAAY,GAAG,iBAAiB,CAAC;QACxC,MAAM,CAAC,aAAa,GAAG,oBAAoB,CAAC;QAC5C,MAAM,CAAC,WAAW,GAAG,iBAAiB,CAAC;QACvC,MAAM,CAAC,kBAAkB,GAAG,IAAI,CAAC;QACjC,MAAM,CAAC,kBAAkB,GAAG,IAAI,CAAC;KAClC;SAAM,IAAI,MAAM,CAAC,cAAc,KAAK,cAAc,EAAE;QACnD,MAAM,CAAC,cAAc,GAAG,cAAc,CAAC;QACvC,MAAM,CAAC,WAAW,EAAE,CAAC;KACtB;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;;;;;AAKD,MAAM,UAAU,iBAAiB;IAC/B,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC;AACxB,CAAC","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 {RElement} from '../interfaces/renderer';\nimport {StylingMapArray} from '../interfaces/styling';\nimport {TEMPLATE_DIRECTIVE_INDEX} from '../util/styling_utils';\n\n/**\n * --------\n *\n * This file contains all state-based logic for styling in Angular.\n *\n * Styling in Angular is evaluated with a series of styling-specific\n * template instructions which are called one after another each time\n * change detection occurs in Angular.\n *\n * Styling makes use of various temporary, state-based variables between\n * instructions so that it can better cache and optimize its values.\n * These values are usually populated and cleared when an element is\n * exited in change detection (once all the instructions are run for\n * that element).\n *\n * To learn more about the algorithm see `TStylingContext`.\n *\n * --------\n */\n\n/**\n * Used as a state reference for update values between style/class binding instructions.\n *\n * In addition to storing the element and bit-mask related values, the state also\n * stores the `sourceIndex` value. The `sourceIndex` value is an incremented value\n * that identifies what \"source\" (i.e. the template, a specific directive by index or\n * component) is currently applying its styling bindings to the element.\n */\nexport interface StylingState {\n  /** The element that is currently being processed */\n  element: RElement|null;\n\n  /** The directive index that is currently active (`0` === template) */\n  directiveIndex: number;\n\n  /** The source (column) index that is currently active (`0` === template) */\n  sourceIndex: number;\n\n  /** The classes update bit mask value that is processed during each class binding */\n  classesBitMask: number;\n\n  /** The classes update bit index value that is processed during each class binding */\n  classesIndex: number;\n\n  /** The styles update bit mask value that is processed during each style binding */\n  stylesBitMask: number;\n\n  /** The styles update bit index value that is processed during each style binding */\n  stylesIndex: number;\n\n  /**\n   * The last class map that was applied (i.e. `[class]=\"x\"`).\n   *\n   * Note that this property is only populated when direct class values are applied\n   * (i.e. context resolution is not used).\n   *\n   * See `allowDirectStyling` for more info.\n  */\n  lastDirectClassMap: StylingMapArray|null;\n\n  /**\n   * The last style map that was applied (i.e. `[style]=\"x\"`)\n   *\n   * Note that this property is only populated when direct style values are applied\n   * (i.e. context resolution is not used).\n   *\n   * See `allowDirectStyling` for more info.\n  */\n  lastDirectStyleMap: StylingMapArray|null;\n}\n\n// these values will get filled in the very first time this is accessed...\nconst _state: StylingState = {\n  element: null,\n  directiveIndex: -1,\n  sourceIndex: -1,\n  classesBitMask: -1,\n  classesIndex: -1,\n  stylesBitMask: -1,\n  stylesIndex: -1,\n  lastDirectClassMap: null,\n  lastDirectStyleMap: null,\n};\n\nconst BIT_MASK_START_VALUE = 0;\n\n// the `0` start value is reserved for [map]-based entries\nconst INDEX_START_VALUE = 1;\n\n/**\n * Returns (or instantiates) the styling state for the given element.\n *\n * Styling state is accessed and processed each time a style or class binding\n * is evaluated.\n *\n * If and when the provided `element` doesn't match the current element in the\n * state then this means that styling was recently cleared or the element has\n * changed in change detection. In both cases the styling state is fully reset.\n *\n * If and when the provided `directiveIndex` doesn't match the current directive\n * index in the state then this means that a new source has introduced itself into\n * the styling code (or, in other words, another directive or component has started\n * to apply its styling host bindings to the element).\n */\nexport function getStylingState(element: RElement, directiveIndex: number): StylingState {\n  if (_state.element !== element) {\n    _state.element = element;\n    _state.directiveIndex = directiveIndex;\n    _state.sourceIndex = directiveIndex === TEMPLATE_DIRECTIVE_INDEX ? 0 : 1;\n    _state.classesBitMask = BIT_MASK_START_VALUE;\n    _state.classesIndex = INDEX_START_VALUE;\n    _state.stylesBitMask = BIT_MASK_START_VALUE;\n    _state.stylesIndex = INDEX_START_VALUE;\n    _state.lastDirectClassMap = null;\n    _state.lastDirectStyleMap = null;\n  } else if (_state.directiveIndex !== directiveIndex) {\n    _state.directiveIndex = directiveIndex;\n    _state.sourceIndex++;\n  }\n  return _state;\n}\n\n/**\n * Clears the styling state so that it can be used by another element's styling code.\n */\nexport function resetStylingState() {\n  _state.element = null;\n}\n"]}