@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,712 +0,0 @@
1
- /**
2
- * @fileoverview added by tsickle
3
- * Generated from: packages/core/src/render3/styling/styling_debug.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 { createProxy } from '../../debug/proxy';
14
- import { getCurrentStyleSanitizer } from '../state';
15
- import { attachDebugObject } from '../util/debug_utils';
16
- 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';
17
- import { applyStylingViaContext } from './bindings';
18
- import { activateStylingMapFeature } from './map_based_bindings';
19
- /**
20
- * A debug-friendly version of `TStylingContext`.
21
- *
22
- * An instance of this is attached to `tStylingContext.debug` when `ngDevMode` is active.
23
- * @record
24
- */
25
- export function DebugStylingContext() { }
26
- if (false) {
27
- /**
28
- * The configuration settings of the associated `TStylingContext`
29
- * @type {?}
30
- */
31
- DebugStylingContext.prototype.config;
32
- /**
33
- * The associated TStylingContext instance
34
- * @type {?}
35
- */
36
- DebugStylingContext.prototype.context;
37
- /**
38
- * The associated TStylingContext instance
39
- * @type {?}
40
- */
41
- DebugStylingContext.prototype.entries;
42
- /**
43
- * A status report of all the sources within the context
44
- * @return {?}
45
- */
46
- DebugStylingContext.prototype.printSources = function () { };
47
- /**
48
- * A status report of all the entire context as a table
49
- * @return {?}
50
- */
51
- DebugStylingContext.prototype.printTable = function () { };
52
- }
53
- /**
54
- * A debug/testing-oriented summary of all styling information in `TNode.flags`.
55
- * @record
56
- */
57
- export function DebugStylingConfig() { }
58
- if (false) {
59
- /** @type {?} */
60
- DebugStylingConfig.prototype.hasMapBindings;
61
- /** @type {?} */
62
- DebugStylingConfig.prototype.hasPropBindings;
63
- /** @type {?} */
64
- DebugStylingConfig.prototype.hasCollisions;
65
- /** @type {?} */
66
- DebugStylingConfig.prototype.hasTemplateBindings;
67
- /** @type {?} */
68
- DebugStylingConfig.prototype.hasHostBindings;
69
- /** @type {?} */
70
- DebugStylingConfig.prototype.allowDirectStyling;
71
- }
72
- /**
73
- * A debug/testing-oriented summary of all styling entries within a `TStylingContext`.
74
- * @record
75
- */
76
- export function DebugStylingContextEntry() { }
77
- if (false) {
78
- /**
79
- * The property (style or class property) that this entry represents
80
- * @type {?}
81
- */
82
- DebugStylingContextEntry.prototype.prop;
83
- /**
84
- * The total amount of styling entries a part of this entry
85
- * @type {?}
86
- */
87
- DebugStylingContextEntry.prototype.valuesCount;
88
- /**
89
- * The bit guard mask that is used to compare and protect against
90
- * styling changes when any template style/class bindings update
91
- * @type {?}
92
- */
93
- DebugStylingContextEntry.prototype.templateBitMask;
94
- /**
95
- * The bit guard mask that is used to compare and protect against
96
- * styling changes when any host style/class bindings update
97
- * @type {?}
98
- */
99
- DebugStylingContextEntry.prototype.hostBindingsBitMask;
100
- /**
101
- * Whether or not the entry requires sanitization
102
- * @type {?}
103
- */
104
- DebugStylingContextEntry.prototype.sanitizationRequired;
105
- /**
106
- * The default value that will be applied if any bindings are falsy
107
- * @type {?}
108
- */
109
- DebugStylingContextEntry.prototype.defaultValue;
110
- /**
111
- * All bindingIndex sources that have been registered for this style
112
- * @type {?}
113
- */
114
- DebugStylingContextEntry.prototype.sources;
115
- }
116
- /**
117
- * A debug/testing-oriented summary of all styling entries for a `DebugNode` instance.
118
- * @record
119
- */
120
- export function DebugNodeStyling() { }
121
- if (false) {
122
- /**
123
- * The associated debug context of the TStylingContext instance
124
- * @type {?}
125
- */
126
- DebugNodeStyling.prototype.context;
127
- /**
128
- * A summarization of each style/class property
129
- * present in the context
130
- * @type {?}
131
- */
132
- DebugNodeStyling.prototype.summary;
133
- /**
134
- * A key/value map of all styling properties and their
135
- * runtime values
136
- * @type {?}
137
- */
138
- DebugNodeStyling.prototype.values;
139
- /**
140
- * Overrides the sanitizer used to process styles
141
- * @param {?} sanitizer
142
- * @return {?}
143
- */
144
- DebugNodeStyling.prototype.overrideSanitizer = function (sanitizer) { };
145
- }
146
- /**
147
- * A debug/testing-oriented summary of a styling entry.
148
- *
149
- * A value such as this is generated as an artifact of the `DebugStyling`
150
- * summary.
151
- * @record
152
- */
153
- export function DebugNodeStylingEntry() { }
154
- if (false) {
155
- /**
156
- * The style/class property that the summary is attached to
157
- * @type {?}
158
- */
159
- DebugNodeStylingEntry.prototype.prop;
160
- /**
161
- * The last applied value for the style/class property
162
- * @type {?}
163
- */
164
- DebugNodeStylingEntry.prototype.value;
165
- /**
166
- * The binding index of the last applied style/class property
167
- * @type {?}
168
- */
169
- DebugNodeStylingEntry.prototype.bindingIndex;
170
- }
171
- /**
172
- * Instantiates and attaches an instance of `TStylingContextDebug` to the provided context
173
- * @param {?} context
174
- * @param {?} tNode
175
- * @param {?} isClassBased
176
- * @return {?}
177
- */
178
- export function attachStylingDebugObject(context, tNode, isClassBased) {
179
- /** @type {?} */
180
- const debug = new TStylingContextDebug(context, tNode, isClassBased);
181
- attachDebugObject(context, debug);
182
- return debug;
183
- }
184
- /**
185
- * A human-readable debug summary of the styling data present within `TStylingContext`.
186
- *
187
- * This class is designed to be used within testing code or when an
188
- * application has `ngDevMode` activated.
189
- */
190
- class TStylingContextDebug {
191
- /**
192
- * @param {?} context
193
- * @param {?} _tNode
194
- * @param {?} _isClassBased
195
- */
196
- constructor(context, _tNode, _isClassBased) {
197
- this.context = context;
198
- this._tNode = _tNode;
199
- this._isClassBased = _isClassBased;
200
- }
201
- /**
202
- * @return {?}
203
- */
204
- get config() { return buildConfig(this._tNode, this._isClassBased); }
205
- /**
206
- * Returns a detailed summary of each styling entry in the context.
207
- *
208
- * See `DebugStylingContextEntry`.
209
- * @return {?}
210
- */
211
- get entries() {
212
- /** @type {?} */
213
- const context = this.context;
214
- /** @type {?} */
215
- const totalColumns = getValuesCount(context);
216
- /** @type {?} */
217
- const entries = {};
218
- /** @type {?} */
219
- const start = getPropValuesStartPosition(context, this._tNode, this._isClassBased);
220
- /** @type {?} */
221
- let i = start;
222
- while (i < context.length) {
223
- /** @type {?} */
224
- const prop = getProp(context, i);
225
- /** @type {?} */
226
- const templateBitMask = getGuardMask(context, i, false);
227
- /** @type {?} */
228
- const hostBindingsBitMask = getGuardMask(context, i, true);
229
- /** @type {?} */
230
- const defaultValue = getDefaultValue(context, i);
231
- /** @type {?} */
232
- const sanitizationRequired = isSanitizationRequired(context, i);
233
- /** @type {?} */
234
- const bindingsStartPosition = i + 4 /* BindingsStartOffset */;
235
- /** @type {?} */
236
- const sources = [];
237
- for (let j = 0; j < totalColumns; j++) {
238
- /** @type {?} */
239
- const bindingIndex = (/** @type {?} */ (context[bindingsStartPosition + j]));
240
- if (bindingIndex !== 0) {
241
- sources.push(bindingIndex);
242
- }
243
- }
244
- entries[prop] = {
245
- prop,
246
- templateBitMask,
247
- hostBindingsBitMask,
248
- sanitizationRequired,
249
- valuesCount: sources.length, defaultValue, sources,
250
- };
251
- i += 4 /* BindingsStartOffset */ + totalColumns;
252
- }
253
- return entries;
254
- }
255
- /**
256
- * Prints a detailed summary of each styling source grouped together with each binding index in
257
- * the context.
258
- * @return {?}
259
- */
260
- printSources() {
261
- /** @type {?} */
262
- let output = '\n';
263
- /** @type {?} */
264
- const context = this.context;
265
- /** @type {?} */
266
- const prefix = this._isClassBased ? 'class' : 'style';
267
- /** @type {?} */
268
- const bindingsBySource = [];
269
- /** @type {?} */
270
- const totalColumns = getValuesCount(context);
271
- /** @type {?} */
272
- const itemsPerRow = 4 /* BindingsStartOffset */ + totalColumns;
273
- for (let i = 0; i < totalColumns; i++) {
274
- /** @type {?} */
275
- const isDefaultColumn = i === totalColumns - 1;
276
- /** @type {?} */
277
- const hostBindingsMode = i !== TEMPLATE_DIRECTIVE_INDEX;
278
- /** @type {?} */
279
- const type = getTypeFromColumn(i, totalColumns);
280
- /** @type {?} */
281
- const entries = [];
282
- /** @type {?} */
283
- let j = 2 /* ValuesStartPosition */;
284
- while (j < context.length) {
285
- /** @type {?} */
286
- const value = getBindingValue(context, j, i);
287
- if (isDefaultColumn || value > 0) {
288
- /** @type {?} */
289
- const bitMask = getGuardMask(context, j, hostBindingsMode);
290
- /** @type {?} */
291
- const bindingIndex = isDefaultColumn ? -1 : (/** @type {?} */ (value));
292
- /** @type {?} */
293
- const prop = getProp(context, j);
294
- /** @type {?} */
295
- const isMapBased = prop === MAP_BASED_ENTRY_PROP_NAME;
296
- /** @type {?} */
297
- const binding = `${prefix}${isMapBased ? '' : '.' + prop}`;
298
- entries.push({ binding, value, bindingIndex, bitMask });
299
- }
300
- j += itemsPerRow;
301
- }
302
- bindingsBySource.push({ type, entries: entries.sort((/**
303
- * @param {?} a
304
- * @param {?} b
305
- * @return {?}
306
- */
307
- (a, b) => a.bindingIndex - b.bindingIndex)) });
308
- }
309
- bindingsBySource.forEach((/**
310
- * @param {?} entry
311
- * @return {?}
312
- */
313
- entry => {
314
- output += `[${entry.type.toUpperCase()}]\n`;
315
- output += repeat('-', entry.type.length + 2) + '\n';
316
- /** @type {?} */
317
- let tab = ' ';
318
- entry.entries.forEach((/**
319
- * @param {?} entry
320
- * @return {?}
321
- */
322
- entry => {
323
- /** @type {?} */
324
- const isDefault = typeof entry.value !== 'number';
325
- /** @type {?} */
326
- const value = entry.value;
327
- if (!isDefault || value !== null) {
328
- output += `${tab}[${entry.binding}] = \`${value}\``;
329
- output += '\n';
330
- }
331
- }));
332
- output += '\n';
333
- }));
334
- /* tslint:disable */
335
- console.log(output);
336
- }
337
- /**
338
- * Prints a detailed table of the entire styling context.
339
- * @return {?}
340
- */
341
- printTable() {
342
- // IE (not Edge) is the only browser that doesn't support this feature. Because
343
- // these debugging tools are not apart of the core of Angular (they are just
344
- // extra tools) we can skip-out on older browsers.
345
- if (!console.table) {
346
- throw new Error('This feature is not supported in your browser');
347
- }
348
- /** @type {?} */
349
- const context = this.context;
350
- /** @type {?} */
351
- const table = [];
352
- /** @type {?} */
353
- const totalColumns = getValuesCount(context);
354
- /** @type {?} */
355
- const itemsPerRow = 4 /* BindingsStartOffset */ + totalColumns;
356
- /** @type {?} */
357
- const totalProps = Math.floor(context.length / itemsPerRow);
358
- /** @type {?} */
359
- let i = 2 /* ValuesStartPosition */;
360
- while (i < context.length) {
361
- /** @type {?} */
362
- const prop = getProp(context, i);
363
- /** @type {?} */
364
- const isMapBased = prop === MAP_BASED_ENTRY_PROP_NAME;
365
- /** @type {?} */
366
- const entry = {
367
- prop,
368
- 'tpl mask': generateBitString(getGuardMask(context, i, false), isMapBased, totalProps),
369
- 'host mask': generateBitString(getGuardMask(context, i, true), isMapBased, totalProps),
370
- };
371
- for (let j = 0; j < totalColumns; j++) {
372
- /** @type {?} */
373
- const key = getTypeFromColumn(j, totalColumns);
374
- /** @type {?} */
375
- const value = getBindingValue(context, i, j);
376
- entry[key] = value;
377
- }
378
- i += itemsPerRow;
379
- table.push(entry);
380
- }
381
- /* tslint:disable */
382
- console.table(table);
383
- }
384
- }
385
- if (false) {
386
- /** @type {?} */
387
- TStylingContextDebug.prototype.context;
388
- /**
389
- * @type {?}
390
- * @private
391
- */
392
- TStylingContextDebug.prototype._tNode;
393
- /**
394
- * @type {?}
395
- * @private
396
- */
397
- TStylingContextDebug.prototype._isClassBased;
398
- }
399
- /**
400
- * @param {?} value
401
- * @param {?} isMapBased
402
- * @param {?} totalProps
403
- * @return {?}
404
- */
405
- function generateBitString(value, isMapBased, totalProps) {
406
- if (isMapBased || value > 1) {
407
- return `0b${leftPad(value.toString(2), totalProps, '0')}`;
408
- }
409
- return null;
410
- }
411
- /**
412
- * @param {?} value
413
- * @param {?} max
414
- * @param {?} pad
415
- * @return {?}
416
- */
417
- function leftPad(value, max, pad) {
418
- return repeat(pad, max - value.length) + value;
419
- }
420
- /**
421
- * @param {?} index
422
- * @param {?} totalColumns
423
- * @return {?}
424
- */
425
- function getTypeFromColumn(index, totalColumns) {
426
- if (index === TEMPLATE_DIRECTIVE_INDEX) {
427
- return 'template';
428
- }
429
- else if (index === totalColumns - 1) {
430
- return 'defaults';
431
- }
432
- else {
433
- return `dir #${index}`;
434
- }
435
- }
436
- /**
437
- * @param {?} c
438
- * @param {?} times
439
- * @return {?}
440
- */
441
- function repeat(c, times) {
442
- /** @type {?} */
443
- let s = '';
444
- for (let i = 0; i < times; i++) {
445
- s += c;
446
- }
447
- return s;
448
- }
449
- /**
450
- * A human-readable debug summary of the styling data present for a `DebugNode` instance.
451
- *
452
- * This class is designed to be used within testing code or when an
453
- * application has `ngDevMode` activated.
454
- */
455
- export class NodeStylingDebug {
456
- /**
457
- * @param {?} context
458
- * @param {?} _tNode
459
- * @param {?} _data
460
- * @param {?} _isClassBased
461
- */
462
- constructor(context, _tNode, _data, _isClassBased) {
463
- this._tNode = _tNode;
464
- this._data = _data;
465
- this._isClassBased = _isClassBased;
466
- this._sanitizer = null;
467
- this._debugContext = isStylingContext(context) ?
468
- new TStylingContextDebug((/** @type {?} */ (context)), _tNode, _isClassBased) :
469
- ((/** @type {?} */ (context)));
470
- }
471
- /**
472
- * @return {?}
473
- */
474
- get context() { return this._debugContext; }
475
- /**
476
- * Overrides the sanitizer used to process styles.
477
- * @param {?} sanitizer
478
- * @return {?}
479
- */
480
- overrideSanitizer(sanitizer) { this._sanitizer = sanitizer; }
481
- /**
482
- * Returns a detailed summary of each styling entry in the context and
483
- * what their runtime representation is.
484
- *
485
- * See `LStylingSummary`.
486
- * @return {?}
487
- */
488
- get summary() {
489
- /** @type {?} */
490
- const entries = {};
491
- /** @type {?} */
492
- const config = this.config;
493
- /** @type {?} */
494
- const isClassBased = this._isClassBased;
495
- /** @type {?} */
496
- let data = this._data;
497
- // the direct pass code doesn't convert [style] or [class] values
498
- // into StylingMapArray instances. For this reason, the values
499
- // need to be converted ahead of time since the styling debug
500
- // relies on context resolution to figure out what styling
501
- // values have been added/removed on the element.
502
- if (config.allowDirectStyling && config.hasMapBindings) {
503
- data = data.concat([]); // make a copy
504
- this._convertMapBindingsToStylingMapArrays(data);
505
- }
506
- this._mapValues(data, (/**
507
- * @param {?} prop
508
- * @param {?} value
509
- * @param {?} bindingIndex
510
- * @return {?}
511
- */
512
- (prop, value, bindingIndex) => {
513
- entries[prop] = { prop, value, bindingIndex };
514
- }));
515
- // because the styling algorithm runs into two different
516
- // modes: direct and context-resolution, the output of the entries
517
- // object is different because the removed values are not
518
- // saved between updates. For this reason a proxy is created
519
- // so that the behavior is the same when examining values
520
- // that are no longer active on the element.
521
- return createProxy({
522
- /**
523
- * @param {?} target
524
- * @param {?} prop
525
- * @return {?}
526
- */
527
- get(target, prop) {
528
- /** @type {?} */
529
- let value = entries[prop];
530
- if (!value) {
531
- value = {
532
- prop,
533
- value: isClassBased ? false : null,
534
- bindingIndex: null,
535
- };
536
- }
537
- return value;
538
- },
539
- /**
540
- * @param {?} target
541
- * @param {?} prop
542
- * @param {?} value
543
- * @return {?}
544
- */
545
- set(target, prop, value) { return false; },
546
- /**
547
- * @return {?}
548
- */
549
- ownKeys() { return Object.keys(entries); },
550
- /**
551
- * @param {?} k
552
- * @return {?}
553
- */
554
- getOwnPropertyDescriptor(k) {
555
- // we use a special property descriptor here so that enumeration operations
556
- // such as `Object.keys` will work on this proxy.
557
- return {
558
- enumerable: true,
559
- configurable: true,
560
- };
561
- },
562
- });
563
- }
564
- /**
565
- * @return {?}
566
- */
567
- get config() { return buildConfig(this._tNode, this._isClassBased); }
568
- /**
569
- * Returns a key/value map of all the styles/classes that were last applied to the element.
570
- * @return {?}
571
- */
572
- get values() {
573
- /** @type {?} */
574
- const entries = {};
575
- /** @type {?} */
576
- const config = this.config;
577
- /** @type {?} */
578
- let data = this._data;
579
- // the direct pass code doesn't convert [style] or [class] values
580
- // into StylingMapArray instances. For this reason, the values
581
- // need to be converted ahead of time since the styling debug
582
- // relies on context resolution to figure out what styling
583
- // values have been added/removed on the element.
584
- if (config.allowDirectStyling && config.hasMapBindings) {
585
- data = data.concat([]); // make a copy
586
- this._convertMapBindingsToStylingMapArrays(data);
587
- }
588
- this._mapValues(data, (/**
589
- * @param {?} prop
590
- * @param {?} value
591
- * @return {?}
592
- */
593
- (prop, value) => { entries[prop] = value; }));
594
- return entries;
595
- }
596
- /**
597
- * @private
598
- * @param {?} data
599
- * @return {?}
600
- */
601
- _convertMapBindingsToStylingMapArrays(data) {
602
- /** @type {?} */
603
- const context = this.context.context;
604
- /** @type {?} */
605
- const limit = getPropValuesStartPosition(context, this._tNode, this._isClassBased);
606
- for (let i = 2 /* ValuesStartPosition */ + 4 /* BindingsStartOffset */; i < limit; i++) {
607
- /** @type {?} */
608
- const bindingIndex = (/** @type {?} */ (context[i]));
609
- /** @type {?} */
610
- const bindingValue = bindingIndex !== 0 ? getValue(data, bindingIndex) : null;
611
- if (bindingValue && !Array.isArray(bindingValue)) {
612
- /** @type {?} */
613
- const stylingMapArray = normalizeIntoStylingMap(null, bindingValue, !this._isClassBased);
614
- setValue(data, bindingIndex, stylingMapArray);
615
- }
616
- }
617
- }
618
- /**
619
- * @private
620
- * @param {?} data
621
- * @param {?} fn
622
- * @return {?}
623
- */
624
- _mapValues(data, fn) {
625
- // there is no need to store/track an element instance. The
626
- // element is only used when the styling algorithm attempts to
627
- // style the value (and we mock out the stylingApplyFn anyway).
628
- /** @type {?} */
629
- const mockElement = (/** @type {?} */ ({}));
630
- /** @type {?} */
631
- const mapBindingsFlag = this._isClassBased ? 512 /* hasClassMapBindings */ : 16384 /* hasStyleMapBindings */;
632
- /** @type {?} */
633
- const hasMaps = hasConfig(this._tNode, mapBindingsFlag);
634
- if (hasMaps) {
635
- activateStylingMapFeature();
636
- }
637
- /** @type {?} */
638
- const mapFn = (/**
639
- * @param {?} renderer
640
- * @param {?} element
641
- * @param {?} prop
642
- * @param {?} value
643
- * @param {?=} bindingIndex
644
- * @return {?}
645
- */
646
- (renderer, element, prop, value, bindingIndex) => fn(prop, value, bindingIndex || null));
647
- /** @type {?} */
648
- const sanitizer = this._isClassBased ? null : (this._sanitizer || getCurrentStyleSanitizer());
649
- // run the template bindings
650
- applyStylingViaContext(this.context.context, this._tNode, null, mockElement, data, true, mapFn, sanitizer, false, this._isClassBased);
651
- // and also the host bindings
652
- applyStylingViaContext(this.context.context, this._tNode, null, mockElement, data, true, mapFn, sanitizer, true, this._isClassBased);
653
- }
654
- }
655
- if (false) {
656
- /**
657
- * @type {?}
658
- * @private
659
- */
660
- NodeStylingDebug.prototype._sanitizer;
661
- /**
662
- * @type {?}
663
- * @private
664
- */
665
- NodeStylingDebug.prototype._debugContext;
666
- /**
667
- * @type {?}
668
- * @private
669
- */
670
- NodeStylingDebug.prototype._tNode;
671
- /**
672
- * @type {?}
673
- * @private
674
- */
675
- NodeStylingDebug.prototype._data;
676
- /**
677
- * @type {?}
678
- * @private
679
- */
680
- NodeStylingDebug.prototype._isClassBased;
681
- }
682
- /**
683
- * @param {?} tNode
684
- * @param {?} isClassBased
685
- * @return {?}
686
- */
687
- function buildConfig(tNode, isClassBased) {
688
- /** @type {?} */
689
- const hasMapBindings = hasConfig(tNode, isClassBased ? 512 /* hasClassMapBindings */ : 16384 /* hasStyleMapBindings */);
690
- /** @type {?} */
691
- const hasPropBindings = hasConfig(tNode, isClassBased ? 1024 /* hasClassPropBindings */ : 32768 /* hasStylePropBindings */);
692
- /** @type {?} */
693
- const hasCollisions = hasConfig(tNode, isClassBased ? 8192 /* hasDuplicateClassBindings */ : 262144 /* hasDuplicateStyleBindings */);
694
- /** @type {?} */
695
- const hasTemplateBindings = hasConfig(tNode, isClassBased ? 2048 /* hasTemplateClassBindings */ : 65536 /* hasTemplateStyleBindings */);
696
- /** @type {?} */
697
- const hasHostBindings = hasConfig(tNode, isClassBased ? 4096 /* hasHostClassBindings */ : 131072 /* hasHostStyleBindings */);
698
- // `firstTemplatePass` here is false because the context has already been constructed
699
- // directly within the behavior of the debugging tools (outside of style/class debugging,
700
- // the context is constructed during the first template pass).
701
- /** @type {?} */
702
- const allowDirectStyling = _allowDirectStyling(tNode, isClassBased, false);
703
- return {
704
- hasMapBindings,
705
- hasPropBindings,
706
- hasCollisions,
707
- hasTemplateBindings,
708
- hasHostBindings,
709
- allowDirectStyling,
710
- };
711
- }
712
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"styling_debug.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/styling/styling_debug.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 {createProxy} from '../../debug/proxy';\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|boolean|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    const isClassBased = this._isClassBased;\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    // because the styling algorithm runs into two different\n    // modes: direct and context-resolution, the output of the entries\n    // object is different because the removed values are not\n    // saved between updates. For this reason a proxy is created\n    // so that the behavior is the same when examining values\n    // that are no longer active on the element.\n    return createProxy({\n      get(target: {}, prop: string): DebugNodeStylingEntry{\n        let value: DebugNodeStylingEntry = entries[prop]; if (!value) {\n          value = {\n            prop,\n            value: isClassBased ? false : null,\n            bindingIndex: null,\n          };\n        } return value;\n      },\n      set(target: {}, prop: string, value: any) { return false; },\n      ownKeys() { return Object.keys(entries); },\n      getOwnPropertyDescriptor(k: any) {\n        // we use a special property descriptor here so that enumeration operations\n        // such as `Object.keys` will work on this proxy.\n        return {\n          enumerable: true,\n          configurable: true,\n        };\n      },\n    });\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"]}