@angular/core 9.0.0-rc.9 → 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 (196) hide show
  1. package/bundles/core-testing.umd.js +10 -9
  2. package/bundles/core-testing.umd.js.map +1 -1
  3. package/bundles/core-testing.umd.min.js +6 -6
  4. package/bundles/core-testing.umd.min.js.map +1 -1
  5. package/bundles/core.umd.js +3619 -3914
  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 +483 -651
  10. package/core.metadata.json +1 -1
  11. package/esm2015/core.js +17 -17
  12. package/esm2015/index.js +2 -2
  13. package/esm2015/public_api.js +2 -2
  14. package/esm2015/src/application_ref.js +7 -7
  15. package/esm2015/src/core.js +3 -3
  16. package/esm2015/src/core_private_export.js +7 -7
  17. package/esm2015/src/core_render3_private_export.js +2 -2
  18. package/esm2015/src/debug/debug_node.js +44 -12
  19. package/esm2015/src/i18n/locale_data_api.js +1 -2
  20. package/esm2015/src/interface/type.js +1 -1
  21. package/esm2015/src/metadata/ng_module.js +1 -1
  22. package/esm2015/src/render/api.js +4 -1
  23. package/esm2015/src/render3/assert.js +9 -1
  24. package/esm2015/src/render3/bindings.js +16 -5
  25. package/esm2015/src/render3/component.js +54 -25
  26. package/esm2015/src/render3/component_ref.js +11 -15
  27. package/esm2015/src/render3/definition.js +3 -1
  28. package/esm2015/src/render3/di.js +3 -4
  29. package/esm2015/src/render3/di_setup.js +5 -7
  30. package/esm2015/src/render3/errors.js +3 -1
  31. package/esm2015/src/render3/features/inherit_definition_feature.js +41 -13
  32. package/esm2015/src/render3/features/ng_onchanges_feature.js +2 -2
  33. package/esm2015/src/render3/global_utils_api.js +3 -3
  34. package/esm2015/src/render3/i18n.js +60 -56
  35. package/esm2015/src/render3/index.js +2 -2
  36. package/esm2015/src/render3/instructions/advance.js +10 -11
  37. package/esm2015/src/render3/instructions/all.js +4 -5
  38. package/esm2015/src/render3/instructions/attribute.js +6 -6
  39. package/esm2015/src/render3/instructions/attribute_interpolation.js +40 -21
  40. package/esm2015/src/render3/instructions/change_detection.js +8 -23
  41. package/esm2015/src/render3/instructions/class_map_interpolation.js +13 -12
  42. package/esm2015/src/render3/instructions/container.js +15 -12
  43. package/esm2015/src/render3/instructions/element.js +40 -127
  44. package/esm2015/src/render3/instructions/element_container.js +8 -10
  45. package/esm2015/src/render3/instructions/embedded_view.js +7 -7
  46. package/esm2015/src/render3/instructions/host_property.js +10 -7
  47. package/esm2015/src/render3/instructions/listener.js +18 -16
  48. package/esm2015/src/render3/instructions/lview_debug.js +160 -23
  49. package/esm2015/src/render3/instructions/projection.js +7 -5
  50. package/esm2015/src/render3/instructions/property.js +27 -6
  51. package/esm2015/src/render3/instructions/property_interpolation.js +40 -22
  52. package/esm2015/src/render3/instructions/shared.js +267 -240
  53. package/esm2015/src/render3/instructions/storage.js +6 -8
  54. package/esm2015/src/render3/instructions/style_prop_interpolation.js +12 -12
  55. package/esm2015/src/render3/instructions/styling.js +731 -475
  56. package/esm2015/src/render3/instructions/text.js +5 -5
  57. package/esm2015/src/render3/interfaces/definition.js +41 -1
  58. package/esm2015/src/render3/interfaces/node.js +160 -115
  59. package/esm2015/src/render3/interfaces/styling.js +183 -375
  60. package/esm2015/src/render3/interfaces/view.js +10 -2
  61. package/esm2015/src/render3/jit/environment.js +1 -3
  62. package/esm2015/src/render3/node_manipulation.js +177 -57
  63. package/esm2015/src/render3/node_selector_matcher.js +39 -24
  64. package/esm2015/src/render3/node_util.js +12 -7
  65. package/esm2015/src/render3/pipe.js +4 -6
  66. package/esm2015/src/render3/query.js +32 -26
  67. package/esm2015/src/render3/state.js +54 -183
  68. package/esm2015/src/render3/styling/class_differ.js +47 -0
  69. package/esm2015/src/render3/styling/static_styling.js +54 -0
  70. package/esm2015/src/render3/styling/style_binding_list.js +437 -0
  71. package/esm2015/src/render3/styling/styling_parser.js +336 -0
  72. package/esm2015/src/render3/tokens.js +2 -2
  73. package/esm2015/src/render3/util/attrs_utils.js +125 -2
  74. package/esm2015/src/render3/util/change_detection_utils.js +33 -0
  75. package/esm2015/src/render3/util/discovery_utils.js +146 -119
  76. package/esm2015/src/render3/util/global_utils.js +5 -5
  77. package/esm2015/src/render3/util/view_utils.js +6 -6
  78. package/esm2015/src/render3/view_engine_compatibility.js +16 -17
  79. package/esm2015/src/render3/view_ref.js +16 -13
  80. package/esm2015/src/sanitization/bypass.js +1 -1
  81. package/esm2015/src/sanitization/sanitization.js +20 -5
  82. package/esm2015/src/util/array_utils.js +240 -1
  83. package/esm2015/src/util/assert.js +37 -21
  84. package/esm2015/src/util/char_code.js +8 -0
  85. package/esm2015/src/util/iterable.js +4 -1
  86. package/esm2015/src/util/ng_dev_mode.js +1 -12
  87. package/esm2015/src/util/stringify.js +14 -1
  88. package/esm2015/src/version.js +1 -1
  89. package/esm2015/testing/src/r3_test_bed.js +5 -1
  90. package/esm2015/testing/src/r3_test_bed_compiler.js +2 -12
  91. package/esm2015/testing/src/styling.js +103 -0
  92. package/esm5/core.js +17 -17
  93. package/esm5/src/application_ref.js +6 -6
  94. package/esm5/src/core_private_export.js +7 -7
  95. package/esm5/src/core_render3_private_export.js +2 -2
  96. package/esm5/src/debug/debug_node.js +29 -11
  97. package/esm5/src/i18n/locale_data_api.js +1 -2
  98. package/esm5/src/interface/type.js +1 -1
  99. package/esm5/src/metadata/ng_module.js +1 -1
  100. package/esm5/src/render/api.js +4 -1
  101. package/esm5/src/render3/assert.js +4 -1
  102. package/esm5/src/render3/bindings.js +19 -2
  103. package/esm5/src/render3/component.js +47 -22
  104. package/esm5/src/render3/component_ref.js +9 -14
  105. package/esm5/src/render3/definition.js +3 -1
  106. package/esm5/src/render3/di.js +3 -4
  107. package/esm5/src/render3/di_setup.js +4 -5
  108. package/esm5/src/render3/errors.js +3 -1
  109. package/esm5/src/render3/features/inherit_definition_feature.js +36 -12
  110. package/esm5/src/render3/features/ng_onchanges_feature.js +1 -1
  111. package/esm5/src/render3/global_utils_api.js +3 -3
  112. package/esm5/src/render3/i18n.js +51 -51
  113. package/esm5/src/render3/index.js +2 -2
  114. package/esm5/src/render3/instructions/advance.js +9 -11
  115. package/esm5/src/render3/instructions/all.js +1 -2
  116. package/esm5/src/render3/instructions/attribute.js +5 -6
  117. package/esm5/src/render3/instructions/attribute_interpolation.js +31 -21
  118. package/esm5/src/render3/instructions/change_detection.js +8 -21
  119. package/esm5/src/render3/instructions/class_map_interpolation.js +13 -12
  120. package/esm5/src/render3/instructions/container.js +13 -12
  121. package/esm5/src/render3/instructions/element.js +36 -108
  122. package/esm5/src/render3/instructions/element_container.js +8 -9
  123. package/esm5/src/render3/instructions/embedded_view.js +7 -7
  124. package/esm5/src/render3/instructions/host_property.js +8 -7
  125. package/esm5/src/render3/instructions/listener.js +13 -13
  126. package/esm5/src/render3/instructions/lview_debug.js +56 -15
  127. package/esm5/src/render3/instructions/projection.js +6 -5
  128. package/esm5/src/render3/instructions/property.js +17 -6
  129. package/esm5/src/render3/instructions/property_interpolation.js +31 -23
  130. package/esm5/src/render3/instructions/shared.js +247 -207
  131. package/esm5/src/render3/instructions/storage.js +4 -6
  132. package/esm5/src/render3/instructions/style_prop_interpolation.js +12 -12
  133. package/esm5/src/render3/instructions/styling.js +685 -367
  134. package/esm5/src/render3/instructions/text.js +5 -5
  135. package/esm5/src/render3/interfaces/definition.js +1 -1
  136. package/esm5/src/render3/interfaces/node.js +49 -1
  137. package/esm5/src/render3/interfaces/styling.js +57 -1
  138. package/esm5/src/render3/interfaces/view.js +1 -1
  139. package/esm5/src/render3/jit/environment.js +1 -3
  140. package/esm5/src/render3/node_manipulation.js +167 -54
  141. package/esm5/src/render3/node_selector_matcher.js +40 -20
  142. package/esm5/src/render3/node_util.js +12 -7
  143. package/esm5/src/render3/pipe.js +4 -6
  144. package/esm5/src/render3/query.js +25 -24
  145. package/esm5/src/render3/state.js +34 -131
  146. package/esm5/src/render3/styling/class_differ.js +39 -0
  147. package/esm5/src/render3/styling/static_styling.js +42 -0
  148. package/esm5/src/render3/styling/style_binding_list.js +411 -0
  149. package/esm5/src/render3/styling/styling_parser.js +265 -0
  150. package/esm5/src/render3/tokens.js +2 -2
  151. package/esm5/src/render3/util/attrs_utils.js +117 -2
  152. package/esm5/src/render3/util/change_detection_utils.js +23 -0
  153. package/esm5/src/render3/util/discovery_utils.js +115 -99
  154. package/esm5/src/render3/util/global_utils.js +5 -5
  155. package/esm5/src/render3/util/view_utils.js +5 -5
  156. package/esm5/src/render3/view_engine_compatibility.js +37 -39
  157. package/esm5/src/render3/view_ref.js +14 -13
  158. package/esm5/src/sanitization/bypass.js +1 -1
  159. package/esm5/src/sanitization/sanitization.js +16 -5
  160. package/esm5/src/util/array_utils.js +240 -1
  161. package/esm5/src/util/assert.js +37 -21
  162. package/esm5/src/util/char_code.js +8 -0
  163. package/esm5/src/util/iterable.js +4 -1
  164. package/esm5/src/util/ng_dev_mode.js +1 -12
  165. package/esm5/src/util/stringify.js +14 -1
  166. package/esm5/src/version.js +1 -1
  167. package/esm5/testing/src/r3_test_bed.js +9 -1
  168. package/esm5/testing/src/r3_test_bed_compiler.js +2 -9
  169. package/esm5/testing/src/styling.js +82 -0
  170. package/fesm2015/core.js +5917 -6880
  171. package/fesm2015/core.js.map +1 -1
  172. package/fesm2015/testing.js +6 -12
  173. package/fesm2015/testing.js.map +1 -1
  174. package/fesm5/core.js +3588 -3884
  175. package/fesm5/core.js.map +1 -1
  176. package/fesm5/testing.js +10 -9
  177. package/fesm5/testing.js.map +1 -1
  178. package/package.json +1 -1
  179. package/src/r3_symbols.d.ts +1 -1
  180. package/testing/testing.d.ts +1 -3
  181. package/testing/testing.metadata.json +1 -1
  182. package/testing.d.ts +1 -1
  183. package/esm2015/global.js +0 -7
  184. package/esm2015/src/render3/instructions/alloc_host_vars.js +0 -80
  185. package/esm2015/src/render3/styling/bindings.js +0 -1248
  186. package/esm2015/src/render3/styling/map_based_bindings.js +0 -384
  187. package/esm2015/src/render3/styling/state.js +0 -135
  188. package/esm2015/src/render3/styling/styling_debug.js +0 -655
  189. package/esm2015/src/render3/util/styling_utils.js +0 -625
  190. package/esm5/global.js +0 -9
  191. package/esm5/src/render3/instructions/alloc_host_vars.js +0 -62
  192. package/esm5/src/render3/styling/bindings.js +0 -949
  193. package/esm5/src/render3/styling/map_based_bindings.js +0 -310
  194. package/esm5/src/render3/styling/state.js +0 -56
  195. package/esm5/src/render3/styling/styling_debug.js +0 -315
  196. package/esm5/src/render3/util/styling_utils.js +0 -378
@@ -1,315 +0,0 @@
1
- import { getCurrentStyleSanitizer } from '../state';
2
- import { attachDebugObject } from '../util/debug_utils';
3
- import { MAP_BASED_ENTRY_PROP_NAME, TEMPLATE_DIRECTIVE_INDEX, allowDirectStyling as _allowDirectStyling, getBindingValue, getDefaultValue, getGuardMask, getProp, getPropValuesStartPosition, getValue, getValuesCount, hasConfig, isSanitizationRequired, isStylingContext, normalizeIntoStylingMap, setValue } from '../util/styling_utils';
4
- import { applyStylingViaContext } from './bindings';
5
- import { activateStylingMapFeature } from './map_based_bindings';
6
- /**
7
- * Instantiates and attaches an instance of `TStylingContextDebug` to the provided context
8
- */
9
- export function attachStylingDebugObject(context, tNode, isClassBased) {
10
- var debug = new TStylingContextDebug(context, tNode, isClassBased);
11
- attachDebugObject(context, debug);
12
- return debug;
13
- }
14
- /**
15
- * A human-readable debug summary of the styling data present within `TStylingContext`.
16
- *
17
- * This class is designed to be used within testing code or when an
18
- * application has `ngDevMode` activated.
19
- */
20
- var TStylingContextDebug = /** @class */ (function () {
21
- function TStylingContextDebug(context, _tNode, _isClassBased) {
22
- this.context = context;
23
- this._tNode = _tNode;
24
- this._isClassBased = _isClassBased;
25
- }
26
- Object.defineProperty(TStylingContextDebug.prototype, "config", {
27
- get: function () { return buildConfig(this._tNode, this._isClassBased); },
28
- enumerable: true,
29
- configurable: true
30
- });
31
- Object.defineProperty(TStylingContextDebug.prototype, "entries", {
32
- /**
33
- * Returns a detailed summary of each styling entry in the context.
34
- *
35
- * See `DebugStylingContextEntry`.
36
- */
37
- get: function () {
38
- var context = this.context;
39
- var totalColumns = getValuesCount(context);
40
- var entries = {};
41
- var start = getPropValuesStartPosition(context, this._tNode, this._isClassBased);
42
- var i = start;
43
- while (i < context.length) {
44
- var prop = getProp(context, i);
45
- var templateBitMask = getGuardMask(context, i, false);
46
- var hostBindingsBitMask = getGuardMask(context, i, true);
47
- var defaultValue = getDefaultValue(context, i);
48
- var sanitizationRequired = isSanitizationRequired(context, i);
49
- var bindingsStartPosition = i + 4 /* BindingsStartOffset */;
50
- var sources = [];
51
- for (var j = 0; j < totalColumns; j++) {
52
- var bindingIndex = context[bindingsStartPosition + j];
53
- if (bindingIndex !== 0) {
54
- sources.push(bindingIndex);
55
- }
56
- }
57
- entries[prop] = {
58
- prop: prop,
59
- templateBitMask: templateBitMask,
60
- hostBindingsBitMask: hostBindingsBitMask,
61
- sanitizationRequired: sanitizationRequired,
62
- valuesCount: sources.length, defaultValue: defaultValue, sources: sources,
63
- };
64
- i += 4 /* BindingsStartOffset */ + totalColumns;
65
- }
66
- return entries;
67
- },
68
- enumerable: true,
69
- configurable: true
70
- });
71
- /**
72
- * Prints a detailed summary of each styling source grouped together with each binding index in
73
- * the context.
74
- */
75
- TStylingContextDebug.prototype.printSources = function () {
76
- var output = '\n';
77
- var context = this.context;
78
- var prefix = this._isClassBased ? 'class' : 'style';
79
- var bindingsBySource = [];
80
- var totalColumns = getValuesCount(context);
81
- var itemsPerRow = 4 /* BindingsStartOffset */ + totalColumns;
82
- for (var i = 0; i < totalColumns; i++) {
83
- var isDefaultColumn = i === totalColumns - 1;
84
- var hostBindingsMode = i !== TEMPLATE_DIRECTIVE_INDEX;
85
- var type = getTypeFromColumn(i, totalColumns);
86
- var entries = [];
87
- var j = 2 /* ValuesStartPosition */;
88
- while (j < context.length) {
89
- var value = getBindingValue(context, j, i);
90
- if (isDefaultColumn || value > 0) {
91
- var bitMask = getGuardMask(context, j, hostBindingsMode);
92
- var bindingIndex = isDefaultColumn ? -1 : value;
93
- var prop = getProp(context, j);
94
- var isMapBased = prop === MAP_BASED_ENTRY_PROP_NAME;
95
- var binding = "" + prefix + (isMapBased ? '' : '.' + prop);
96
- entries.push({ binding: binding, value: value, bindingIndex: bindingIndex, bitMask: bitMask });
97
- }
98
- j += itemsPerRow;
99
- }
100
- bindingsBySource.push({ type: type, entries: entries.sort(function (a, b) { return a.bindingIndex - b.bindingIndex; }) });
101
- }
102
- bindingsBySource.forEach(function (entry) {
103
- output += "[" + entry.type.toUpperCase() + "]\n";
104
- output += repeat('-', entry.type.length + 2) + '\n';
105
- var tab = ' ';
106
- entry.entries.forEach(function (entry) {
107
- var isDefault = typeof entry.value !== 'number';
108
- var value = entry.value;
109
- if (!isDefault || value !== null) {
110
- output += tab + "[" + entry.binding + "] = `" + value + "`";
111
- output += '\n';
112
- }
113
- });
114
- output += '\n';
115
- });
116
- /* tslint:disable */
117
- console.log(output);
118
- };
119
- /**
120
- * Prints a detailed table of the entire styling context.
121
- */
122
- TStylingContextDebug.prototype.printTable = function () {
123
- // IE (not Edge) is the only browser that doesn't support this feature. Because
124
- // these debugging tools are not apart of the core of Angular (they are just
125
- // extra tools) we can skip-out on older browsers.
126
- if (!console.table) {
127
- throw new Error('This feature is not supported in your browser');
128
- }
129
- var context = this.context;
130
- var table = [];
131
- var totalColumns = getValuesCount(context);
132
- var itemsPerRow = 4 /* BindingsStartOffset */ + totalColumns;
133
- var totalProps = Math.floor(context.length / itemsPerRow);
134
- var i = 2 /* ValuesStartPosition */;
135
- while (i < context.length) {
136
- var prop = getProp(context, i);
137
- var isMapBased = prop === MAP_BASED_ENTRY_PROP_NAME;
138
- var entry = {
139
- prop: prop,
140
- 'tpl mask': generateBitString(getGuardMask(context, i, false), isMapBased, totalProps),
141
- 'host mask': generateBitString(getGuardMask(context, i, true), isMapBased, totalProps),
142
- };
143
- for (var j = 0; j < totalColumns; j++) {
144
- var key = getTypeFromColumn(j, totalColumns);
145
- var value = getBindingValue(context, i, j);
146
- entry[key] = value;
147
- }
148
- i += itemsPerRow;
149
- table.push(entry);
150
- }
151
- /* tslint:disable */
152
- console.table(table);
153
- };
154
- return TStylingContextDebug;
155
- }());
156
- function generateBitString(value, isMapBased, totalProps) {
157
- if (isMapBased || value > 1) {
158
- return "0b" + leftPad(value.toString(2), totalProps, '0');
159
- }
160
- return null;
161
- }
162
- function leftPad(value, max, pad) {
163
- return repeat(pad, max - value.length) + value;
164
- }
165
- function getTypeFromColumn(index, totalColumns) {
166
- if (index === TEMPLATE_DIRECTIVE_INDEX) {
167
- return 'template';
168
- }
169
- else if (index === totalColumns - 1) {
170
- return 'defaults';
171
- }
172
- else {
173
- return "dir #" + index;
174
- }
175
- }
176
- function repeat(c, times) {
177
- var s = '';
178
- for (var i = 0; i < times; i++) {
179
- s += c;
180
- }
181
- return s;
182
- }
183
- /**
184
- * A human-readable debug summary of the styling data present for a `DebugNode` instance.
185
- *
186
- * This class is designed to be used within testing code or when an
187
- * application has `ngDevMode` activated.
188
- */
189
- var NodeStylingDebug = /** @class */ (function () {
190
- function NodeStylingDebug(context, _tNode, _data, _isClassBased) {
191
- this._tNode = _tNode;
192
- this._data = _data;
193
- this._isClassBased = _isClassBased;
194
- this._sanitizer = null;
195
- this._debugContext = isStylingContext(context) ?
196
- new TStylingContextDebug(context, _tNode, _isClassBased) :
197
- context;
198
- }
199
- Object.defineProperty(NodeStylingDebug.prototype, "context", {
200
- get: function () { return this._debugContext; },
201
- enumerable: true,
202
- configurable: true
203
- });
204
- /**
205
- * Overrides the sanitizer used to process styles.
206
- */
207
- NodeStylingDebug.prototype.overrideSanitizer = function (sanitizer) { this._sanitizer = sanitizer; };
208
- Object.defineProperty(NodeStylingDebug.prototype, "summary", {
209
- /**
210
- * Returns a detailed summary of each styling entry in the context and
211
- * what their runtime representation is.
212
- *
213
- * See `LStylingSummary`.
214
- */
215
- get: function () {
216
- var entries = {};
217
- var config = this.config;
218
- var data = this._data;
219
- // the direct pass code doesn't convert [style] or [class] values
220
- // into StylingMapArray instances. For this reason, the values
221
- // need to be converted ahead of time since the styling debug
222
- // relies on context resolution to figure out what styling
223
- // values have been added/removed on the element.
224
- if (config.allowDirectStyling && config.hasMapBindings) {
225
- data = data.concat([]); // make a copy
226
- this._convertMapBindingsToStylingMapArrays(data);
227
- }
228
- this._mapValues(data, function (prop, value, bindingIndex) {
229
- entries[prop] = { prop: prop, value: value, bindingIndex: bindingIndex };
230
- });
231
- return entries;
232
- },
233
- enumerable: true,
234
- configurable: true
235
- });
236
- Object.defineProperty(NodeStylingDebug.prototype, "config", {
237
- get: function () { return buildConfig(this._tNode, this._isClassBased); },
238
- enumerable: true,
239
- configurable: true
240
- });
241
- Object.defineProperty(NodeStylingDebug.prototype, "values", {
242
- /**
243
- * Returns a key/value map of all the styles/classes that were last applied to the element.
244
- */
245
- get: function () {
246
- var entries = {};
247
- var config = this.config;
248
- var data = this._data;
249
- // the direct pass code doesn't convert [style] or [class] values
250
- // into StylingMapArray instances. For this reason, the values
251
- // need to be converted ahead of time since the styling debug
252
- // relies on context resolution to figure out what styling
253
- // values have been added/removed on the element.
254
- if (config.allowDirectStyling && config.hasMapBindings) {
255
- data = data.concat([]); // make a copy
256
- this._convertMapBindingsToStylingMapArrays(data);
257
- }
258
- this._mapValues(data, function (prop, value) { entries[prop] = value; });
259
- return entries;
260
- },
261
- enumerable: true,
262
- configurable: true
263
- });
264
- NodeStylingDebug.prototype._convertMapBindingsToStylingMapArrays = function (data) {
265
- var context = this.context.context;
266
- var limit = getPropValuesStartPosition(context, this._tNode, this._isClassBased);
267
- for (var i = 2 /* ValuesStartPosition */ + 4 /* BindingsStartOffset */; i < limit; i++) {
268
- var bindingIndex = context[i];
269
- var bindingValue = bindingIndex !== 0 ? getValue(data, bindingIndex) : null;
270
- if (bindingValue && !Array.isArray(bindingValue)) {
271
- var stylingMapArray = normalizeIntoStylingMap(null, bindingValue, !this._isClassBased);
272
- setValue(data, bindingIndex, stylingMapArray);
273
- }
274
- }
275
- };
276
- NodeStylingDebug.prototype._mapValues = function (data, fn) {
277
- // there is no need to store/track an element instance. The
278
- // element is only used when the styling algorithm attempts to
279
- // style the value (and we mock out the stylingApplyFn anyway).
280
- var mockElement = {};
281
- var mapBindingsFlag = this._isClassBased ? 512 /* hasClassMapBindings */ : 16384 /* hasStyleMapBindings */;
282
- var hasMaps = hasConfig(this._tNode, mapBindingsFlag);
283
- if (hasMaps) {
284
- activateStylingMapFeature();
285
- }
286
- var mapFn = function (renderer, element, prop, value, bindingIndex) { return fn(prop, value, bindingIndex || null); };
287
- var sanitizer = this._isClassBased ? null : (this._sanitizer || getCurrentStyleSanitizer());
288
- // run the template bindings
289
- applyStylingViaContext(this.context.context, this._tNode, null, mockElement, data, true, mapFn, sanitizer, false, this._isClassBased);
290
- // and also the host bindings
291
- applyStylingViaContext(this.context.context, this._tNode, null, mockElement, data, true, mapFn, sanitizer, true, this._isClassBased);
292
- };
293
- return NodeStylingDebug;
294
- }());
295
- export { NodeStylingDebug };
296
- function buildConfig(tNode, isClassBased) {
297
- var hasMapBindings = hasConfig(tNode, isClassBased ? 512 /* hasClassMapBindings */ : 16384 /* hasStyleMapBindings */);
298
- var hasPropBindings = hasConfig(tNode, isClassBased ? 1024 /* hasClassPropBindings */ : 32768 /* hasStylePropBindings */);
299
- var hasCollisions = hasConfig(tNode, isClassBased ? 8192 /* hasDuplicateClassBindings */ : 262144 /* hasDuplicateStyleBindings */);
300
- var hasTemplateBindings = hasConfig(tNode, isClassBased ? 2048 /* hasTemplateClassBindings */ : 65536 /* hasTemplateStyleBindings */);
301
- var hasHostBindings = hasConfig(tNode, isClassBased ? 4096 /* hasHostClassBindings */ : 131072 /* hasHostStyleBindings */);
302
- // `firstTemplatePass` here is false because the context has already been constructed
303
- // directly within the behavior of the debugging tools (outside of style/class debugging,
304
- // the context is constructed during the first template pass).
305
- var allowDirectStyling = _allowDirectStyling(tNode, isClassBased, false);
306
- return {
307
- hasMapBindings: hasMapBindings,
308
- hasPropBindings: hasPropBindings,
309
- hasCollisions: hasCollisions,
310
- hasTemplateBindings: hasTemplateBindings,
311
- hasHostBindings: hasHostBindings,
312
- allowDirectStyling: allowDirectStyling,
313
- };
314
- }
315
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"styling_debug.js","sourceRoot":"","sources":["../../../../../../../../../../../packages/core/src/render3/styling/styling_debug.ts"],"names":[],"mappings":"AAWA,OAAO,EAAC,wBAAwB,EAAC,MAAM,UAAU,CAAC;AAClD,OAAO,EAAC,iBAAiB,EAAC,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAC,yBAAyB,EAAE,wBAAwB,EAAE,kBAAkB,IAAI,mBAAmB,EAAE,eAAe,EAAE,eAAe,EAAE,YAAY,EAAE,OAAO,EAAE,0BAA0B,EAAE,QAAQ,EAAE,cAAc,EAAE,SAAS,EAAE,sBAAsB,EAAE,gBAAgB,EAAE,uBAAuB,EAAE,QAAQ,EAAC,MAAM,uBAAuB,CAAC;AAE5U,OAAO,EAAC,sBAAsB,EAAC,MAAM,YAAY,CAAC;AAClD,OAAO,EAAC,yBAAyB,EAAC,MAAM,sBAAsB,CAAC;AAqI/D;;GAEG;AACH,MAAM,UAAU,wBAAwB,CACpC,OAAwB,EAAE,KAAmB,EAAE,YAAqB;IACtE,IAAM,KAAK,GAAG,IAAI,oBAAoB,CAAC,OAAO,EAAE,KAAK,EAAE,YAAY,CAAC,CAAC;IACrE,iBAAiB,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;IAClC,OAAO,KAAK,CAAC;AACf,CAAC;AAED;;;;;GAKG;AACH;IACE,8BACoB,OAAwB,EAAU,MAAoB,EAC9D,aAAsB;QADd,YAAO,GAAP,OAAO,CAAiB;QAAU,WAAM,GAAN,MAAM,CAAc;QAC9D,kBAAa,GAAb,aAAa,CAAS;IAAG,CAAC;IAEtC,sBAAI,wCAAM;aAAV,cAAmC,OAAO,WAAW,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;;;OAAA;IAOzF,sBAAI,yCAAO;QALX;;;;WAIG;aACH;YACE,IAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;YAC7B,IAAM,YAAY,GAAG,cAAc,CAAC,OAAO,CAAC,CAAC;YAC7C,IAAM,OAAO,GAA+C,EAAE,CAAC;YAC/D,IAAM,KAAK,GAAG,0BAA0B,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;YACnF,IAAI,CAAC,GAAG,KAAK,CAAC;YACd,OAAO,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE;gBACzB,IAAM,IAAI,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;gBACjC,IAAM,eAAe,GAAG,YAAY,CAAC,OAAO,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC;gBACxD,IAAM,mBAAmB,GAAG,YAAY,CAAC,OAAO,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC;gBAC3D,IAAM,YAAY,GAAG,eAAe,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;gBACjD,IAAM,oBAAoB,GAAG,sBAAsB,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;gBAChE,IAAM,qBAAqB,GAAG,CAAC,8BAA2C,CAAC;gBAE3E,IAAM,OAAO,GAA+B,EAAE,CAAC;gBAE/C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,YAAY,EAAE,CAAC,EAAE,EAAE;oBACrC,IAAM,YAAY,GAAG,OAAO,CAAC,qBAAqB,GAAG,CAAC,CAA2B,CAAC;oBAClF,IAAI,YAAY,KAAK,CAAC,EAAE;wBACtB,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;qBAC5B;iBACF;gBAED,OAAO,CAAC,IAAI,CAAC,GAAG;oBACd,IAAI,MAAA;oBACJ,eAAe,iBAAA;oBACf,mBAAmB,qBAAA;oBACnB,oBAAoB,sBAAA;oBACpB,WAAW,EAAE,OAAO,CAAC,MAAM,EAAE,YAAY,cAAA,EAAE,OAAO,SAAA;iBACnD,CAAC;gBAEF,CAAC,IAAI,8BAA2C,YAAY,CAAC;aAC9D;YACD,OAAO,OAAO,CAAC;QACjB,CAAC;;;OAAA;IAED;;;OAGG;IACH,2CAAY,GAAZ;QACE,IAAI,MAAM,GAAG,IAAI,CAAC;QAElB,IAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC7B,IAAM,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC;QACtD,IAAM,gBAAgB,GAGhB,EAAE,CAAC;QAET,IAAM,YAAY,GAAG,cAAc,CAAC,OAAO,CAAC,CAAC;QAC7C,IAAM,WAAW,GAAG,8BAA2C,YAAY,CAAC;QAE5E,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,YAAY,EAAE,CAAC,EAAE,EAAE;YACrC,IAAM,eAAe,GAAG,CAAC,KAAK,YAAY,GAAG,CAAC,CAAC;YAC/C,IAAM,gBAAgB,GAAG,CAAC,KAAK,wBAAwB,CAAC;YACxD,IAAM,IAAI,GAAG,iBAAiB,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC;YAChD,IAAM,OAAO,GAA2E,EAAE,CAAC;YAE3F,IAAI,CAAC,8BAA2C,CAAC;YACjD,OAAO,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE;gBACzB,IAAM,KAAK,GAAG,eAAe,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;gBAC7C,IAAI,eAAe,IAAI,KAAK,GAAG,CAAC,EAAE;oBAChC,IAAM,OAAO,GAAG,YAAY,CAAC,OAAO,EAAE,CAAC,EAAE,gBAAgB,CAAC,CAAC;oBAC3D,IAAM,YAAY,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAe,CAAC;oBAC5D,IAAM,IAAI,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;oBACjC,IAAM,UAAU,GAAG,IAAI,KAAK,yBAAyB,CAAC;oBACtD,IAAM,OAAO,GAAG,KAAG,MAAM,IAAG,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,GAAG,IAAI,CAAE,CAAC;oBAC3D,OAAO,CAAC,IAAI,CAAC,EAAC,OAAO,SAAA,EAAE,KAAK,OAAA,EAAE,YAAY,cAAA,EAAE,OAAO,SAAA,EAAC,CAAC,CAAC;iBACvD;gBACD,CAAC,IAAI,WAAW,CAAC;aAClB;YAED,gBAAgB,CAAC,IAAI,CACjB,EAAC,IAAI,MAAA,EAAE,OAAO,EAAE,OAAO,CAAC,IAAI,CAAC,UAAC,CAAC,EAAE,CAAC,IAAK,OAAA,CAAC,CAAC,YAAY,GAAG,CAAC,CAAC,YAAY,EAA/B,CAA+B,CAAC,EAAC,CAAC,CAAC;SAC/E;QAED,gBAAgB,CAAC,OAAO,CAAC,UAAA,KAAK;YAC5B,MAAM,IAAI,MAAI,KAAK,CAAC,IAAI,CAAC,WAAW,EAAE,QAAK,CAAC;YAC5C,MAAM,IAAI,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC;YAEpD,IAAI,GAAG,GAAG,IAAI,CAAC;YACf,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,UAAA,KAAK;gBACzB,IAAM,SAAS,GAAG,OAAO,KAAK,CAAC,KAAK,KAAK,QAAQ,CAAC;gBAClD,IAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;gBAC1B,IAAI,CAAC,SAAS,IAAI,KAAK,KAAK,IAAI,EAAE;oBAChC,MAAM,IAAO,GAAG,SAAI,KAAK,CAAC,OAAO,aAAS,KAAK,MAAI,CAAC;oBACpD,MAAM,IAAI,IAAI,CAAC;iBAChB;YACH,CAAC,CAAC,CAAC;YACH,MAAM,IAAI,IAAI,CAAC;QACjB,CAAC,CAAC,CAAC;QAEH,oBAAoB;QACpB,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IACtB,CAAC;IAED;;OAEG;IACH,yCAAU,GAAV;QACE,+EAA+E;QAC/E,4EAA4E;QAC5E,kDAAkD;QAClD,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE;YAClB,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAC;SAClE;QAED,IAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC7B,IAAM,KAAK,GAAU,EAAE,CAAC;QACxB,IAAM,YAAY,GAAG,cAAc,CAAC,OAAO,CAAC,CAAC;QAC7C,IAAM,WAAW,GAAG,8BAA2C,YAAY,CAAC;QAC5E,IAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,WAAW,CAAC,CAAC;QAE5D,IAAI,CAAC,8BAA2C,CAAC;QACjD,OAAO,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE;YACzB,IAAM,IAAI,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;YACjC,IAAM,UAAU,GAAG,IAAI,KAAK,yBAAyB,CAAC;YACtD,IAAM,KAAK,GAAyB;gBAClC,IAAI,MAAA;gBACJ,UAAU,EAAE,iBAAiB,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC,EAAE,KAAK,CAAC,EAAE,UAAU,EAAE,UAAU,CAAC;gBACtF,WAAW,EAAE,iBAAiB,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE,UAAU,EAAE,UAAU,CAAC;aACvF,CAAC;YAEF,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,YAAY,EAAE,CAAC,EAAE,EAAE;gBACrC,IAAM,GAAG,GAAG,iBAAiB,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC;gBAC/C,IAAM,KAAK,GAAG,eAAe,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;gBAC7C,KAAK,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;aACpB;YAED,CAAC,IAAI,WAAW,CAAC;YACjB,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACnB;QAED,oBAAoB;QACpB,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC;IACH,2BAAC;AAAD,CAAC,AArJD,IAqJC;AAED,SAAS,iBAAiB,CAAC,KAAa,EAAE,UAAmB,EAAE,UAAkB;IAC/E,IAAI,UAAU,IAAI,KAAK,GAAG,CAAC,EAAE;QAC3B,OAAO,OAAK,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,UAAU,EAAE,GAAG,CAAG,CAAC;KAC3D;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAED,SAAS,OAAO,CAAC,KAAa,EAAE,GAAW,EAAE,GAAW;IACtD,OAAO,MAAM,CAAC,GAAG,EAAE,GAAG,GAAG,KAAK,CAAC,MAAM,CAAC,GAAG,KAAK,CAAC;AACjD,CAAC;AAED,SAAS,iBAAiB,CAAC,KAAa,EAAE,YAAoB;IAC5D,IAAI,KAAK,KAAK,wBAAwB,EAAE;QACtC,OAAO,UAAU,CAAC;KACnB;SAAM,IAAI,KAAK,KAAK,YAAY,GAAG,CAAC,EAAE;QACrC,OAAO,UAAU,CAAC;KACnB;SAAM;QACL,OAAO,UAAQ,KAAO,CAAC;KACxB;AACH,CAAC;AAED,SAAS,MAAM,CAAC,CAAS,EAAE,KAAa;IACtC,IAAI,CAAC,GAAG,EAAE,CAAC;IACX,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,EAAE,EAAE;QAC9B,CAAC,IAAI,CAAC,CAAC;KACR;IACD,OAAO,CAAC,CAAC;AACX,CAAC;AAED;;;;;GAKG;AACH;IAIE,0BACI,OAA4C,EAAU,MAAoB,EAClE,KAAmB,EAAU,aAAsB;QADL,WAAM,GAAN,MAAM,CAAc;QAClE,UAAK,GAAL,KAAK,CAAc;QAAU,kBAAa,GAAb,aAAa,CAAS;QALvD,eAAU,GAAyB,IAAI,CAAC;QAM9C,IAAI,CAAC,aAAa,GAAG,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC;YAC5C,IAAI,oBAAoB,CAAC,OAA0B,EAAE,MAAM,EAAE,aAAa,CAAC,CAAC,CAAC;YAC5E,OAA+B,CAAC;IACvC,CAAC;IAED,sBAAI,qCAAO;aAAX,cAAgB,OAAO,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC;;;OAAA;IAE5C;;OAEG;IACH,4CAAiB,GAAjB,UAAkB,SAA+B,IAAI,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC,CAAC,CAAC;IAQnF,sBAAI,qCAAO;QANX;;;;;WAKG;aACH;YACE,IAAM,OAAO,GAA2C,EAAE,CAAC;YAC3D,IAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;YAE3B,IAAI,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC;YAEtB,iEAAiE;YACjE,8DAA8D;YAC9D,6DAA6D;YAC7D,0DAA0D;YAC1D,iDAAiD;YACjD,IAAI,MAAM,CAAC,kBAAkB,IAAI,MAAM,CAAC,cAAc,EAAE;gBACtD,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAE,cAAc;gBACvC,IAAI,CAAC,qCAAqC,CAAC,IAAI,CAAC,CAAC;aAClD;YAED,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,UAAC,IAAY,EAAE,KAAU,EAAE,YAA2B;gBAC1E,OAAO,CAAC,IAAI,CAAC,GAAG,EAAC,IAAI,MAAA,EAAE,KAAK,OAAA,EAAE,YAAY,cAAA,EAAC,CAAC;YAC9C,CAAC,CAAC,CAAC;YAEH,OAAO,OAAO,CAAC;QACjB,CAAC;;;OAAA;IAED,sBAAI,oCAAM;aAAV,cAAe,OAAO,WAAW,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;;;OAAA;IAKrE,sBAAI,oCAAM;QAHV;;WAEG;aACH;YACE,IAAM,OAAO,GAAyB,EAAE,CAAC;YACzC,IAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;YAC3B,IAAI,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC;YAEtB,iEAAiE;YACjE,8DAA8D;YAC9D,6DAA6D;YAC7D,0DAA0D;YAC1D,iDAAiD;YACjD,IAAI,MAAM,CAAC,kBAAkB,IAAI,MAAM,CAAC,cAAc,EAAE;gBACtD,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAE,cAAc;gBACvC,IAAI,CAAC,qCAAqC,CAAC,IAAI,CAAC,CAAC;aAClD;YAED,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,UAAC,IAAY,EAAE,KAAU,IAAO,OAAO,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;YAChF,OAAO,OAAO,CAAC;QACjB,CAAC;;;OAAA;IAEO,gEAAqC,GAA7C,UAA8C,IAAkB;QAC9D,IAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC;QACrC,IAAM,KAAK,GAAG,0BAA0B,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QACnF,KAAK,IAAI,CAAC,GACD,yDAAmF,EACvF,CAAC,GAAG,KAAK,EAAE,CAAC,EAAE,EAAE;YACnB,IAAM,YAAY,GAAG,OAAO,CAAC,CAAC,CAAW,CAAC;YAC1C,IAAM,YAAY,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;YAC9E,IAAI,YAAY,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE;gBAChD,IAAM,eAAe,GAAG,uBAAuB,CAAC,IAAI,EAAE,YAAY,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;gBACzF,QAAQ,CAAC,IAAI,EAAE,YAAY,EAAE,eAAe,CAAC,CAAC;aAC/C;SACF;IACH,CAAC;IAEO,qCAAU,GAAlB,UACI,IAAkB,EAClB,EAAwE;QAC1E,2DAA2D;QAC3D,8DAA8D;QAC9D,+DAA+D;QAC/D,IAAM,WAAW,GAAG,EAAS,CAAC;QAC9B,IAAM,eAAe,GACjB,IAAI,CAAC,aAAa,CAAC,CAAC,+BAAgC,CAAC,gCAA+B,CAAC;QACzF,IAAM,OAAO,GAAG,SAAS,CAAC,IAAI,CAAC,MAAM,EAAE,eAAe,CAAC,CAAC;QACxD,IAAI,OAAO,EAAE;YACX,yBAAyB,EAAE,CAAC;SAC7B;QAED,IAAM,KAAK,GACP,UAAC,QAAa,EAAE,OAAiB,EAAE,IAAY,EAAE,KAAoB,EACpE,YAA4B,IAAK,OAAA,EAAE,CAAC,IAAI,EAAE,KAAK,EAAE,YAAY,IAAI,IAAI,CAAC,EAArC,CAAqC,CAAC;QAE5E,IAAM,SAAS,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,IAAI,wBAAwB,EAAE,CAAC,CAAC;QAE9F,4BAA4B;QAC5B,sBAAsB,CAClB,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EACzF,IAAI,CAAC,aAAa,CAAC,CAAC;QAExB,6BAA6B;QAC7B,sBAAsB,CAClB,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,IAAI,EACxF,IAAI,CAAC,aAAa,CAAC,CAAC;IAC1B,CAAC;IACH,uBAAC;AAAD,CAAC,AArHD,IAqHC;;AAED,SAAS,WAAW,CAAC,KAAmB,EAAE,YAAqB;IAC7D,IAAM,cAAc,GAAG,SAAS,CAC5B,KAAK,EAAE,YAAY,CAAC,CAAC,+BAAgC,CAAC,gCAA+B,CAAC,CAAC;IAC3F,IAAM,eAAe,GAAG,SAAS,CAC7B,KAAK,EAAE,YAAY,CAAC,CAAC,iCAAiC,CAAC,iCAAgC,CAAC,CAAC;IAC7F,IAAM,aAAa,GAAG,SAAS,CAC3B,KAAK,EACL,YAAY,CAAC,CAAC,sCAAsC,CAAC,uCAAqC,CAAC,CAAC;IAChG,IAAM,mBAAmB,GAAG,SAAS,CACjC,KAAK,EACL,YAAY,CAAC,CAAC,qCAAqC,CAAC,qCAAoC,CAAC,CAAC;IAC9F,IAAM,eAAe,GAAG,SAAS,CAC7B,KAAK,EAAE,YAAY,CAAC,CAAC,iCAAiC,CAAC,kCAAgC,CAAC,CAAC;IAE7F,qFAAqF;IACrF,yFAAyF;IACzF,8DAA8D;IAC9D,IAAM,kBAAkB,GAAG,mBAAmB,CAAC,KAAK,EAAE,YAAY,EAAE,KAAK,CAAC,CAAC;IAC3E,OAAO;QACH,cAAc,gBAAA;QACd,eAAe,iBAAA;QACf,aAAa,eAAA;QACb,mBAAmB,qBAAA;QACnB,eAAe,iBAAA;QACf,kBAAkB,oBAAA;KACrB,CAAC;AACJ,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 {StyleSanitizeFn} from '../../sanitization/style_sanitizer';\nimport {TNodeFlags} from '../interfaces/node';\nimport {RElement} from '../interfaces/renderer';\nimport {ApplyStylingFn, LStylingData, TStylingContext, TStylingContextIndex, TStylingNode} from '../interfaces/styling';\nimport {getCurrentStyleSanitizer} from '../state';\nimport {attachDebugObject} from '../util/debug_utils';\nimport {MAP_BASED_ENTRY_PROP_NAME, TEMPLATE_DIRECTIVE_INDEX, allowDirectStyling as _allowDirectStyling, getBindingValue, getDefaultValue, getGuardMask, getProp, getPropValuesStartPosition, getValue, getValuesCount, hasConfig, isSanitizationRequired, isStylingContext, normalizeIntoStylingMap, setValue} from '../util/styling_utils';\n\nimport {applyStylingViaContext} from './bindings';\nimport {activateStylingMapFeature} from './map_based_bindings';\n\n\n\n/**\n * --------\n *\n * This file contains the core debug functionality for styling in Angular.\n *\n * To learn more about the algorithm see `TStylingContext`.\n *\n * --------\n */\n\n/**\n * A debug-friendly version of `TStylingContext`.\n *\n * An instance of this is attached to `tStylingContext.debug` when `ngDevMode` is active.\n */\nexport interface DebugStylingContext {\n  /** The configuration settings of the associated `TStylingContext` */\n  config: DebugStylingConfig;\n\n  /** The associated TStylingContext instance */\n  context: TStylingContext;\n\n  /** The associated TStylingContext instance */\n  entries: {[prop: string]: DebugStylingContextEntry};\n\n  /** A status report of all the sources within the context */\n  printSources(): void;\n\n  /** A status report of all the entire context as a table */\n  printTable(): void;\n}\n\n\n/**\n * A debug/testing-oriented summary of all styling information in `TNode.flags`.\n */\nexport interface DebugStylingConfig {\n  hasMapBindings: boolean;       //\n  hasPropBindings: boolean;      //\n  hasCollisions: boolean;        //\n  hasTemplateBindings: boolean;  //\n  hasHostBindings: boolean;      //\n  allowDirectStyling: boolean;   //\n}\n\n\n/**\n * A debug/testing-oriented summary of all styling entries within a `TStylingContext`.\n */\nexport interface DebugStylingContextEntry {\n  /** The property (style or class property) that this entry represents */\n  prop: string;\n\n  /** The total amount of styling entries a part of this entry */\n  valuesCount: number;\n\n  /**\n   * The bit guard mask that is used to compare and protect against\n   * styling changes when any template style/class bindings update\n   */\n  templateBitMask: number;\n\n  /**\n   * The bit guard mask that is used to compare and protect against\n   * styling changes when any host style/class bindings update\n   */\n  hostBindingsBitMask: number;\n\n  /**\n   * Whether or not the entry requires sanitization\n   */\n  sanitizationRequired: boolean;\n\n  /**\n   * The default value that will be applied if any bindings are falsy\n   */\n  defaultValue: string|boolean|null;\n\n  /**\n   * All bindingIndex sources that have been registered for this style\n   */\n  sources: (number|null|string)[];\n}\n\n\n/**\n * A debug/testing-oriented summary of all styling entries for a `DebugNode` instance.\n */\nexport interface DebugNodeStyling {\n  /** The associated debug context of the TStylingContext instance */\n  context: DebugStylingContext;\n\n  /**\n   * A summarization of each style/class property\n   * present in the context\n   */\n  summary: {[propertyName: string]: DebugNodeStylingEntry};\n\n  /**\n   * A key/value map of all styling properties and their\n   * runtime values\n   */\n  values: {[propertyName: string]: string | number | null | boolean};\n\n  /**\n   * Overrides the sanitizer used to process styles\n   */\n  overrideSanitizer(sanitizer: StyleSanitizeFn|null): void;\n}\n\n\n/**\n * A debug/testing-oriented summary of a styling entry.\n *\n * A value such as this is generated as an artifact of the `DebugStyling`\n * summary.\n */\nexport interface DebugNodeStylingEntry {\n  /** The style/class property that the summary is attached to */\n  prop: string;\n\n  /** The last applied value for the style/class property */\n  value: string|null;\n\n  /** The binding index of the last applied style/class property */\n  bindingIndex: number|null;\n}\n\n\n/**\n * Instantiates and attaches an instance of `TStylingContextDebug` to the provided context\n */\nexport function attachStylingDebugObject(\n    context: TStylingContext, tNode: TStylingNode, isClassBased: boolean) {\n  const debug = new TStylingContextDebug(context, tNode, isClassBased);\n  attachDebugObject(context, debug);\n  return debug;\n}\n\n/**\n * A human-readable debug summary of the styling data present within `TStylingContext`.\n *\n * This class is designed to be used within testing code or when an\n * application has `ngDevMode` activated.\n */\nclass TStylingContextDebug implements DebugStylingContext {\n  constructor(\n      public readonly context: TStylingContext, private _tNode: TStylingNode,\n      private _isClassBased: boolean) {}\n\n  get config(): DebugStylingConfig { return buildConfig(this._tNode, this._isClassBased); }\n\n  /**\n   * Returns a detailed summary of each styling entry in the context.\n   *\n   * See `DebugStylingContextEntry`.\n   */\n  get entries(): {[prop: string]: DebugStylingContextEntry} {\n    const context = this.context;\n    const totalColumns = getValuesCount(context);\n    const entries: {[prop: string]: DebugStylingContextEntry} = {};\n    const start = getPropValuesStartPosition(context, this._tNode, this._isClassBased);\n    let i = start;\n    while (i < context.length) {\n      const prop = getProp(context, i);\n      const templateBitMask = getGuardMask(context, i, false);\n      const hostBindingsBitMask = getGuardMask(context, i, true);\n      const defaultValue = getDefaultValue(context, i);\n      const sanitizationRequired = isSanitizationRequired(context, i);\n      const bindingsStartPosition = i + TStylingContextIndex.BindingsStartOffset;\n\n      const sources: (number | string | null)[] = [];\n\n      for (let j = 0; j < totalColumns; j++) {\n        const bindingIndex = context[bindingsStartPosition + j] as number | string | null;\n        if (bindingIndex !== 0) {\n          sources.push(bindingIndex);\n        }\n      }\n\n      entries[prop] = {\n        prop,\n        templateBitMask,\n        hostBindingsBitMask,\n        sanitizationRequired,\n        valuesCount: sources.length, defaultValue, sources,\n      };\n\n      i += TStylingContextIndex.BindingsStartOffset + totalColumns;\n    }\n    return entries;\n  }\n\n  /**\n   * Prints a detailed summary of each styling source grouped together with each binding index in\n   * the context.\n   */\n  printSources(): void {\n    let output = '\\n';\n\n    const context = this.context;\n    const prefix = this._isClassBased ? 'class' : 'style';\n    const bindingsBySource: {\n      type: string,\n      entries: {binding: string, bindingIndex: number, value: any, bitMask: number}[]\n    }[] = [];\n\n    const totalColumns = getValuesCount(context);\n    const itemsPerRow = TStylingContextIndex.BindingsStartOffset + totalColumns;\n\n    for (let i = 0; i < totalColumns; i++) {\n      const isDefaultColumn = i === totalColumns - 1;\n      const hostBindingsMode = i !== TEMPLATE_DIRECTIVE_INDEX;\n      const type = getTypeFromColumn(i, totalColumns);\n      const entries: {binding: string, value: any, bindingIndex: number, bitMask: number}[] = [];\n\n      let j = TStylingContextIndex.ValuesStartPosition;\n      while (j < context.length) {\n        const value = getBindingValue(context, j, i);\n        if (isDefaultColumn || value > 0) {\n          const bitMask = getGuardMask(context, j, hostBindingsMode);\n          const bindingIndex = isDefaultColumn ? -1 : value as number;\n          const prop = getProp(context, j);\n          const isMapBased = prop === MAP_BASED_ENTRY_PROP_NAME;\n          const binding = `${prefix}${isMapBased ? '' : '.' + prop}`;\n          entries.push({binding, value, bindingIndex, bitMask});\n        }\n        j += itemsPerRow;\n      }\n\n      bindingsBySource.push(\n          {type, entries: entries.sort((a, b) => a.bindingIndex - b.bindingIndex)});\n    }\n\n    bindingsBySource.forEach(entry => {\n      output += `[${entry.type.toUpperCase()}]\\n`;\n      output += repeat('-', entry.type.length + 2) + '\\n';\n\n      let tab = '  ';\n      entry.entries.forEach(entry => {\n        const isDefault = typeof entry.value !== 'number';\n        const value = entry.value;\n        if (!isDefault || value !== null) {\n          output += `${tab}[${entry.binding}] = \\`${value}\\``;\n          output += '\\n';\n        }\n      });\n      output += '\\n';\n    });\n\n    /* tslint:disable */\n    console.log(output);\n  }\n\n  /**\n   * Prints a detailed table of the entire styling context.\n   */\n  printTable(): void {\n    // IE (not Edge) is the only browser that doesn't support this feature. Because\n    // these debugging tools are not apart of the core of Angular (they are just\n    // extra tools) we can skip-out on older browsers.\n    if (!console.table) {\n      throw new Error('This feature is not supported in your browser');\n    }\n\n    const context = this.context;\n    const table: any[] = [];\n    const totalColumns = getValuesCount(context);\n    const itemsPerRow = TStylingContextIndex.BindingsStartOffset + totalColumns;\n    const totalProps = Math.floor(context.length / itemsPerRow);\n\n    let i = TStylingContextIndex.ValuesStartPosition;\n    while (i < context.length) {\n      const prop = getProp(context, i);\n      const isMapBased = prop === MAP_BASED_ENTRY_PROP_NAME;\n      const entry: {[key: string]: any} = {\n        prop,\n        'tpl mask': generateBitString(getGuardMask(context, i, false), isMapBased, totalProps),\n        'host mask': generateBitString(getGuardMask(context, i, true), isMapBased, totalProps),\n      };\n\n      for (let j = 0; j < totalColumns; j++) {\n        const key = getTypeFromColumn(j, totalColumns);\n        const value = getBindingValue(context, i, j);\n        entry[key] = value;\n      }\n\n      i += itemsPerRow;\n      table.push(entry);\n    }\n\n    /* tslint:disable */\n    console.table(table);\n  }\n}\n\nfunction generateBitString(value: number, isMapBased: boolean, totalProps: number) {\n  if (isMapBased || value > 1) {\n    return `0b${leftPad(value.toString(2), totalProps, '0')}`;\n  }\n  return null;\n}\n\nfunction leftPad(value: string, max: number, pad: string) {\n  return repeat(pad, max - value.length) + value;\n}\n\nfunction getTypeFromColumn(index: number, totalColumns: number) {\n  if (index === TEMPLATE_DIRECTIVE_INDEX) {\n    return 'template';\n  } else if (index === totalColumns - 1) {\n    return 'defaults';\n  } else {\n    return `dir #${index}`;\n  }\n}\n\nfunction repeat(c: string, times: number) {\n  let s = '';\n  for (let i = 0; i < times; i++) {\n    s += c;\n  }\n  return s;\n}\n\n/**\n * A human-readable debug summary of the styling data present for a `DebugNode` instance.\n *\n * This class is designed to be used within testing code or when an\n * application has `ngDevMode` activated.\n */\nexport class NodeStylingDebug implements DebugNodeStyling {\n  private _sanitizer: StyleSanitizeFn|null = null;\n  private _debugContext: DebugStylingContext;\n\n  constructor(\n      context: TStylingContext|DebugStylingContext, private _tNode: TStylingNode,\n      private _data: LStylingData, private _isClassBased: boolean) {\n    this._debugContext = isStylingContext(context) ?\n        new TStylingContextDebug(context as TStylingContext, _tNode, _isClassBased) :\n        (context as DebugStylingContext);\n  }\n\n  get context() { return this._debugContext; }\n\n  /**\n   * Overrides the sanitizer used to process styles.\n   */\n  overrideSanitizer(sanitizer: StyleSanitizeFn|null) { this._sanitizer = sanitizer; }\n\n  /**\n   * Returns a detailed summary of each styling entry in the context and\n   * what their runtime representation is.\n   *\n   * See `LStylingSummary`.\n   */\n  get summary(): {[key: string]: DebugNodeStylingEntry} {\n    const entries: {[key: string]: DebugNodeStylingEntry} = {};\n    const config = this.config;\n\n    let data = this._data;\n\n    // the direct pass code doesn't convert [style] or [class] values\n    // into StylingMapArray instances. For this reason, the values\n    // need to be converted ahead of time since the styling debug\n    // relies on context resolution to figure out what styling\n    // values have been added/removed on the element.\n    if (config.allowDirectStyling && config.hasMapBindings) {\n      data = data.concat([]);  // make a copy\n      this._convertMapBindingsToStylingMapArrays(data);\n    }\n\n    this._mapValues(data, (prop: string, value: any, bindingIndex: number | null) => {\n      entries[prop] = {prop, value, bindingIndex};\n    });\n\n    return entries;\n  }\n\n  get config() { return buildConfig(this._tNode, this._isClassBased); }\n\n  /**\n   * Returns a key/value map of all the styles/classes that were last applied to the element.\n   */\n  get values(): {[key: string]: any} {\n    const entries: {[key: string]: any} = {};\n    const config = this.config;\n    let data = this._data;\n\n    // the direct pass code doesn't convert [style] or [class] values\n    // into StylingMapArray instances. For this reason, the values\n    // need to be converted ahead of time since the styling debug\n    // relies on context resolution to figure out what styling\n    // values have been added/removed on the element.\n    if (config.allowDirectStyling && config.hasMapBindings) {\n      data = data.concat([]);  // make a copy\n      this._convertMapBindingsToStylingMapArrays(data);\n    }\n\n    this._mapValues(data, (prop: string, value: any) => { entries[prop] = value; });\n    return entries;\n  }\n\n  private _convertMapBindingsToStylingMapArrays(data: LStylingData) {\n    const context = this.context.context;\n    const limit = getPropValuesStartPosition(context, this._tNode, this._isClassBased);\n    for (let i =\n             TStylingContextIndex.ValuesStartPosition + TStylingContextIndex.BindingsStartOffset;\n         i < limit; i++) {\n      const bindingIndex = context[i] as number;\n      const bindingValue = bindingIndex !== 0 ? getValue(data, bindingIndex) : null;\n      if (bindingValue && !Array.isArray(bindingValue)) {\n        const stylingMapArray = normalizeIntoStylingMap(null, bindingValue, !this._isClassBased);\n        setValue(data, bindingIndex, stylingMapArray);\n      }\n    }\n  }\n\n  private _mapValues(\n      data: LStylingData,\n      fn: (prop: string, value: string|null, bindingIndex: number|null) => any) {\n    // there is no need to store/track an element instance. The\n    // element is only used when the styling algorithm attempts to\n    // style the value (and we mock out the stylingApplyFn anyway).\n    const mockElement = {} as any;\n    const mapBindingsFlag =\n        this._isClassBased ? TNodeFlags.hasClassMapBindings : TNodeFlags.hasStyleMapBindings;\n    const hasMaps = hasConfig(this._tNode, mapBindingsFlag);\n    if (hasMaps) {\n      activateStylingMapFeature();\n    }\n\n    const mapFn: ApplyStylingFn =\n        (renderer: any, element: RElement, prop: string, value: string | null,\n         bindingIndex?: number | null) => fn(prop, value, bindingIndex || null);\n\n    const sanitizer = this._isClassBased ? null : (this._sanitizer || getCurrentStyleSanitizer());\n\n    // run the template bindings\n    applyStylingViaContext(\n        this.context.context, this._tNode, null, mockElement, data, true, mapFn, sanitizer, false,\n        this._isClassBased);\n\n    // and also the host bindings\n    applyStylingViaContext(\n        this.context.context, this._tNode, null, mockElement, data, true, mapFn, sanitizer, true,\n        this._isClassBased);\n  }\n}\n\nfunction buildConfig(tNode: TStylingNode, isClassBased: boolean): DebugStylingConfig {\n  const hasMapBindings = hasConfig(\n      tNode, isClassBased ? TNodeFlags.hasClassMapBindings : TNodeFlags.hasStyleMapBindings);\n  const hasPropBindings = hasConfig(\n      tNode, isClassBased ? TNodeFlags.hasClassPropBindings : TNodeFlags.hasStylePropBindings);\n  const hasCollisions = hasConfig(\n      tNode,\n      isClassBased ? TNodeFlags.hasDuplicateClassBindings : TNodeFlags.hasDuplicateStyleBindings);\n  const hasTemplateBindings = hasConfig(\n      tNode,\n      isClassBased ? TNodeFlags.hasTemplateClassBindings : TNodeFlags.hasTemplateStyleBindings);\n  const hasHostBindings = hasConfig(\n      tNode, isClassBased ? TNodeFlags.hasHostClassBindings : TNodeFlags.hasHostStyleBindings);\n\n  // `firstTemplatePass` here is false because the context has already been constructed\n  // directly within the behavior of the debugging tools (outside of style/class debugging,\n  // the context is constructed during the first template pass).\n  const allowDirectStyling = _allowDirectStyling(tNode, isClassBased, false);\n  return {\n      hasMapBindings,       //\n      hasPropBindings,      //\n      hasCollisions,        //\n      hasTemplateBindings,  //\n      hasHostBindings,      //\n      allowDirectStyling,   //\n  };\n}\n"]}