@angular/core 8.0.3 → 8.1.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (206) hide show
  1. package/bundles/core-testing.umd.js +35 -9
  2. package/bundles/core-testing.umd.js.map +1 -1
  3. package/bundles/core-testing.umd.min.js +10 -10
  4. package/bundles/core-testing.umd.min.js.map +1 -1
  5. package/bundles/core.umd.js +11379 -9387
  6. package/bundles/core.umd.js.map +1 -1
  7. package/bundles/core.umd.min.js +205 -135
  8. package/bundles/core.umd.min.js.map +1 -1
  9. package/core.d.ts +1286 -406
  10. package/core.metadata.json +1 -1
  11. package/esm2015/core.js +2 -3
  12. package/esm2015/index.js +2 -2
  13. package/esm2015/public_api.js +2 -2
  14. package/esm2015/src/application_ref.js +7 -1
  15. package/esm2015/src/codegen_private_exports.js +2 -2
  16. package/esm2015/src/compiler/compiler_facade_interface.js +1 -1
  17. package/esm2015/src/core.js +4 -4
  18. package/esm2015/src/core_private_export.js +3 -1
  19. package/esm2015/src/core_render3_private_export.js +5 -3
  20. package/esm2015/src/debug/debug_node.js +4 -4
  21. package/esm2015/src/di/index.js +3 -3
  22. package/esm2015/src/di/injectable.js +1 -1
  23. package/esm2015/src/di/injector.js +24 -96
  24. package/esm2015/src/di/injector_compatibility.js +103 -6
  25. package/esm2015/src/di/interface/defs.js +24 -3
  26. package/esm2015/src/di/interface/provider.js +1 -1
  27. package/esm2015/src/di/r3_injector.js +82 -49
  28. package/esm2015/src/di/reflective_injector.js +3 -2
  29. package/esm2015/src/di.js +1 -1
  30. package/esm2015/src/i18n/locale_data.js +61 -0
  31. package/esm2015/src/i18n/locale_data_api.js +53 -0
  32. package/esm2015/src/i18n/locale_en.js +51 -0
  33. package/esm2015/src/i18n/localization.js +37 -0
  34. package/esm2015/src/linker/ng_module_factory_loader.js +4 -52
  35. package/esm2015/src/linker/ng_module_factory_registration.js +83 -0
  36. package/esm2015/src/metadata/directives.js +2 -2
  37. package/esm2015/src/metadata/ng_module.js +6 -1
  38. package/esm2015/src/metadata/resource_loading.js +2 -2
  39. package/esm2015/src/reflection/reflection_capabilities.js +14 -3
  40. package/esm2015/src/render3/assert.js +3 -2
  41. package/esm2015/src/render3/component.js +11 -5
  42. package/esm2015/src/render3/component_ref.js +4 -2
  43. package/esm2015/src/render3/debug.js +23 -15
  44. package/esm2015/src/render3/definition.js +12 -2
  45. package/esm2015/src/render3/errors.js +29 -1
  46. package/esm2015/src/render3/features/inherit_definition_feature.js +51 -37
  47. package/esm2015/src/render3/fields.js +3 -1
  48. package/esm2015/src/render3/i18n.js +76 -465
  49. package/esm2015/src/render3/index.js +3 -3
  50. package/esm2015/src/render3/instructions/all.js +10 -5
  51. package/esm2015/src/render3/instructions/attribute.js +28 -0
  52. package/esm2015/src/render3/instructions/attribute_interpolation.js +376 -0
  53. package/esm2015/src/render3/instructions/container.js +17 -16
  54. package/esm2015/src/render3/instructions/element.js +57 -35
  55. package/esm2015/src/render3/instructions/element_container.js +9 -8
  56. package/esm2015/src/render3/instructions/embedded_view.js +9 -12
  57. package/esm2015/src/render3/instructions/interpolation.js +375 -0
  58. package/esm2015/src/render3/instructions/listener.js +3 -2
  59. package/esm2015/src/render3/instructions/projection.js +18 -57
  60. package/esm2015/src/render3/instructions/property.js +10 -4
  61. package/esm2015/src/render3/instructions/property_interpolation.js +49 -382
  62. package/esm2015/src/render3/instructions/shared.js +82 -118
  63. package/esm2015/src/render3/instructions/styling.js +189 -236
  64. package/esm2015/src/render3/instructions/text.js +8 -7
  65. package/esm2015/src/render3/instructions/text_interpolation.js +357 -0
  66. package/esm2015/src/render3/interfaces/container.js +9 -5
  67. package/esm2015/src/render3/interfaces/definition.js +12 -6
  68. package/esm2015/src/render3/interfaces/node.js +20 -8
  69. package/esm2015/src/render3/interfaces/projection.js +1 -1
  70. package/esm2015/src/render3/interfaces/styling.js +16 -15
  71. package/esm2015/src/render3/interfaces/view.js +2 -2
  72. package/esm2015/src/render3/jit/directive.js +14 -5
  73. package/esm2015/src/render3/jit/environment.js +30 -15
  74. package/esm2015/src/render3/jit/module.js +38 -19
  75. package/esm2015/src/render3/ng_module_ref.js +39 -3
  76. package/esm2015/src/render3/node_manipulation.js +45 -43
  77. package/esm2015/src/render3/node_selector_matcher.js +40 -14
  78. package/esm2015/src/render3/query.js +77 -61
  79. package/esm2015/src/render3/state.js +33 -6
  80. package/esm2015/src/render3/styling/class_and_style_bindings.js +92 -80
  81. package/esm2015/src/render3/styling/host_instructions_queue.js +8 -5
  82. package/esm2015/src/render3/styling/shared.js +2 -2
  83. package/esm2015/src/render3/styling/util.js +2 -2
  84. package/esm2015/src/render3/styling_next/bindings.js +602 -0
  85. package/esm2015/src/render3/styling_next/instructions.js +366 -0
  86. package/esm2015/src/render3/styling_next/interfaces.js +374 -0
  87. package/esm2015/src/render3/styling_next/map_based_bindings.js +408 -0
  88. package/esm2015/src/render3/styling_next/state.js +51 -0
  89. package/esm2015/src/render3/styling_next/styling_debug.js +291 -0
  90. package/esm2015/src/render3/styling_next/util.js +259 -0
  91. package/esm2015/src/render3/util/attrs_utils.js +4 -3
  92. package/esm2015/src/render3/util/debug_utils.js +18 -0
  93. package/esm2015/src/render3/util/view_traversal_utils.js +2 -2
  94. package/esm2015/src/render3/view_engine_compatibility.js +24 -10
  95. package/esm2015/src/sanitization/sanitization.js +17 -7
  96. package/esm2015/src/sanitization/style_sanitizer.js +11 -1
  97. package/esm2015/src/util/ng_dev_mode.js +7 -3
  98. package/esm2015/src/version.js +1 -1
  99. package/esm2015/src/view/ng_module.js +3 -3
  100. package/esm2015/src/view/util.js +2 -2
  101. package/esm2015/testing/src/r3_test_bed_compiler.js +44 -12
  102. package/esm2015/testing/src/test_bed_common.js +2 -5
  103. package/esm5/core.js +2 -3
  104. package/esm5/src/application_ref.js +6 -1
  105. package/esm5/src/codegen_private_exports.js +2 -2
  106. package/esm5/src/compiler/compiler_facade_interface.js +1 -1
  107. package/esm5/src/core_private_export.js +3 -1
  108. package/esm5/src/core_render3_private_export.js +5 -3
  109. package/esm5/src/debug/debug_node.js +4 -4
  110. package/esm5/src/di/index.js +3 -3
  111. package/esm5/src/di/injectable.js +1 -1
  112. package/esm5/src/di/injector.js +14 -74
  113. package/esm5/src/di/injector_compatibility.js +77 -6
  114. package/esm5/src/di/interface/defs.js +24 -3
  115. package/esm5/src/di/interface/provider.js +1 -1
  116. package/esm5/src/di/r3_injector.js +60 -37
  117. package/esm5/src/di/reflective_injector.js +3 -2
  118. package/esm5/src/i18n/locale_data.js +38 -0
  119. package/esm5/src/i18n/locale_data_api.js +46 -0
  120. package/esm5/src/i18n/locale_en.js +39 -0
  121. package/esm5/src/i18n/localization.js +29 -0
  122. package/esm5/src/linker/ng_module_factory_loader.js +4 -32
  123. package/esm5/src/linker/ng_module_factory_registration.js +50 -0
  124. package/esm5/src/metadata/directives.js +2 -2
  125. package/esm5/src/metadata/ng_module.js +1 -1
  126. package/esm5/src/metadata/resource_loading.js +2 -2
  127. package/esm5/src/reflection/reflection_capabilities.js +14 -3
  128. package/esm5/src/render3/assert.js +2 -1
  129. package/esm5/src/render3/component.js +10 -4
  130. package/esm5/src/render3/component_ref.js +4 -2
  131. package/esm5/src/render3/debug.js +17 -10
  132. package/esm5/src/render3/definition.js +8 -2
  133. package/esm5/src/render3/errors.js +14 -1
  134. package/esm5/src/render3/features/inherit_definition_feature.js +41 -36
  135. package/esm5/src/render3/fields.js +2 -1
  136. package/esm5/src/render3/i18n.js +67 -437
  137. package/esm5/src/render3/index.js +3 -3
  138. package/esm5/src/render3/instructions/all.js +6 -1
  139. package/esm5/src/render3/instructions/attribute.js +22 -0
  140. package/esm5/src/render3/instructions/attribute_interpolation.js +346 -0
  141. package/esm5/src/render3/instructions/container.js +16 -15
  142. package/esm5/src/render3/instructions/element.js +43 -32
  143. package/esm5/src/render3/instructions/element_container.js +9 -8
  144. package/esm5/src/render3/instructions/embedded_view.js +8 -11
  145. package/esm5/src/render3/instructions/interpolation.js +243 -0
  146. package/esm5/src/render3/instructions/listener.js +3 -2
  147. package/esm5/src/render3/instructions/projection.js +19 -54
  148. package/esm5/src/render3/instructions/property.js +10 -4
  149. package/esm5/src/render3/instructions/property_interpolation.js +40 -254
  150. package/esm5/src/render3/instructions/shared.js +70 -105
  151. package/esm5/src/render3/instructions/styling.js +167 -209
  152. package/esm5/src/render3/instructions/text.js +8 -7
  153. package/esm5/src/render3/instructions/text_interpolation.js +264 -0
  154. package/esm5/src/render3/interfaces/container.js +8 -2
  155. package/esm5/src/render3/interfaces/definition.js +1 -1
  156. package/esm5/src/render3/interfaces/node.js +1 -8
  157. package/esm5/src/render3/interfaces/projection.js +1 -1
  158. package/esm5/src/render3/interfaces/styling.js +2 -2
  159. package/esm5/src/render3/interfaces/view.js +1 -1
  160. package/esm5/src/render3/jit/directive.js +12 -5
  161. package/esm5/src/render3/jit/environment.js +30 -15
  162. package/esm5/src/render3/jit/module.js +23 -18
  163. package/esm5/src/render3/ng_module_ref.js +37 -3
  164. package/esm5/src/render3/node_manipulation.js +39 -38
  165. package/esm5/src/render3/node_selector_matcher.js +36 -14
  166. package/esm5/src/render3/query.js +75 -53
  167. package/esm5/src/render3/state.js +29 -5
  168. package/esm5/src/render3/styling/class_and_style_bindings.js +80 -66
  169. package/esm5/src/render3/styling/host_instructions_queue.js +6 -3
  170. package/esm5/src/render3/styling/shared.js +2 -2
  171. package/esm5/src/render3/styling/util.js +2 -2
  172. package/esm5/src/render3/styling_next/bindings.js +446 -0
  173. package/esm5/src/render3/styling_next/instructions.js +277 -0
  174. package/esm5/src/render3/styling_next/interfaces.js +1 -0
  175. package/esm5/src/render3/styling_next/map_based_bindings.js +324 -0
  176. package/esm5/src/render3/styling_next/state.js +23 -0
  177. package/esm5/src/render3/styling_next/styling_debug.js +130 -0
  178. package/esm5/src/render3/styling_next/util.js +147 -0
  179. package/esm5/src/render3/util/attrs_utils.js +4 -3
  180. package/esm5/src/render3/util/debug_utils.js +11 -0
  181. package/esm5/src/render3/util/view_traversal_utils.js +2 -2
  182. package/esm5/src/render3/view_engine_compatibility.js +23 -10
  183. package/esm5/src/sanitization/sanitization.js +14 -6
  184. package/esm5/src/sanitization/style_sanitizer.js +1 -1
  185. package/esm5/src/util/ng_dev_mode.js +7 -3
  186. package/esm5/src/version.js +1 -1
  187. package/esm5/src/view/ng_module.js +3 -3
  188. package/esm5/src/view/util.js +2 -2
  189. package/esm5/testing/src/r3_test_bed_compiler.js +37 -11
  190. package/esm5/testing/src/test_bed_common.js +1 -1
  191. package/fesm2015/core.js +13604 -10868
  192. package/fesm2015/core.js.map +1 -1
  193. package/fesm2015/testing.js +43 -11
  194. package/fesm2015/testing.js.map +1 -1
  195. package/fesm5/core.js +11279 -9305
  196. package/fesm5/core.js.map +1 -1
  197. package/fesm5/testing.js +36 -10
  198. package/fesm5/testing.js.map +1 -1
  199. package/package.json +1 -1
  200. package/schematics/migrations/injectable-pipe/index.js +2 -5
  201. package/schematics/migrations/move-document/index.js +2 -5
  202. package/schematics/migrations/static-queries/index.js +2 -5
  203. package/schematics/migrations/template-var-assignment/index.js +2 -5
  204. package/src/r3_symbols.d.ts +24 -18
  205. package/testing/testing.d.ts +2 -5
  206. package/testing.d.ts +1 -1
@@ -0,0 +1,291 @@
1
+ /**
2
+ * @fileoverview added by tsickle
3
+ * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
+ */
5
+ import { attachDebugObject } from '../util/debug_utils';
6
+ import { applyStyling } from './bindings';
7
+ import { activeStylingMapFeature } from './map_based_bindings';
8
+ import { getCurrentOrLViewSanitizer, getDefaultValue, getGuardMask, getProp, getValuesCount, isContextLocked, isSanitizationRequired } from './util';
9
+ /**
10
+ * A debug/testing-oriented summary of a styling entry.
11
+ *
12
+ * A value such as this is generated as an artifact of the `DebugStyling`
13
+ * summary.
14
+ * @record
15
+ */
16
+ export function LStylingSummary() { }
17
+ if (false) {
18
+ /**
19
+ * The style/class property that the summary is attached to
20
+ * @type {?}
21
+ */
22
+ LStylingSummary.prototype.prop;
23
+ /**
24
+ * The last applied value for the style/class property
25
+ * @type {?}
26
+ */
27
+ LStylingSummary.prototype.value;
28
+ /**
29
+ * The binding index of the last applied style/class property
30
+ * @type {?}
31
+ */
32
+ LStylingSummary.prototype.bindingIndex;
33
+ }
34
+ /**
35
+ * A debug/testing-oriented summary of all styling entries for a `DebugNode` instance.
36
+ * @record
37
+ */
38
+ export function DebugStyling() { }
39
+ if (false) {
40
+ /**
41
+ * The associated TStylingContext instance
42
+ * @type {?}
43
+ */
44
+ DebugStyling.prototype.context;
45
+ /**
46
+ * A summarization of each style/class property
47
+ * present in the context.
48
+ * @type {?}
49
+ */
50
+ DebugStyling.prototype.summary;
51
+ /**
52
+ * A key/value map of all styling properties and their
53
+ * runtime values.
54
+ * @type {?}
55
+ */
56
+ DebugStyling.prototype.values;
57
+ /**
58
+ * Overrides the sanitizer used to process styles.
59
+ * @param {?} sanitizer
60
+ * @return {?}
61
+ */
62
+ DebugStyling.prototype.overrideSanitizer = function (sanitizer) { };
63
+ }
64
+ /**
65
+ * A debug/testing-oriented summary of all styling entries within a `TStylingContext`.
66
+ * @record
67
+ */
68
+ export function TStylingTupleSummary() { }
69
+ if (false) {
70
+ /**
71
+ * The property (style or class property) that this tuple represents
72
+ * @type {?}
73
+ */
74
+ TStylingTupleSummary.prototype.prop;
75
+ /**
76
+ * The total amount of styling entries apart of this tuple
77
+ * @type {?}
78
+ */
79
+ TStylingTupleSummary.prototype.valuesCount;
80
+ /**
81
+ * The bit guard mask that is used to compare and protect against
82
+ * styling changes when and styling bindings update
83
+ * @type {?}
84
+ */
85
+ TStylingTupleSummary.prototype.guardMask;
86
+ /**
87
+ * Whether or not the entry requires sanitization
88
+ * @type {?}
89
+ */
90
+ TStylingTupleSummary.prototype.sanitizationRequired;
91
+ /**
92
+ * The default value that will be applied if any bindings are falsy.
93
+ * @type {?}
94
+ */
95
+ TStylingTupleSummary.prototype.defaultValue;
96
+ /**
97
+ * All bindingIndex sources that have been registered for this style.
98
+ * @type {?}
99
+ */
100
+ TStylingTupleSummary.prototype.sources;
101
+ }
102
+ /**
103
+ * Instantiates and attaches an instance of `TStylingContextDebug` to the provided context.
104
+ * @param {?} context
105
+ * @return {?}
106
+ */
107
+ export function attachStylingDebugObject(context) {
108
+ /** @type {?} */
109
+ const debug = new TStylingContextDebug(context);
110
+ attachDebugObject(context, debug);
111
+ return debug;
112
+ }
113
+ /**
114
+ * A human-readable debug summary of the styling data present within `TStylingContext`.
115
+ *
116
+ * This class is designed to be used within testing code or when an
117
+ * application has `ngDevMode` activated.
118
+ */
119
+ class TStylingContextDebug {
120
+ /**
121
+ * @param {?} context
122
+ */
123
+ constructor(context) {
124
+ this.context = context;
125
+ }
126
+ /**
127
+ * @return {?}
128
+ */
129
+ get isLocked() { return isContextLocked(this.context); }
130
+ /**
131
+ * Returns a detailed summary of each styling entry in the context.
132
+ *
133
+ * See `TStylingTupleSummary`.
134
+ * @return {?}
135
+ */
136
+ get entries() {
137
+ /** @type {?} */
138
+ const context = this.context;
139
+ /** @type {?} */
140
+ const entries = {};
141
+ /** @type {?} */
142
+ const start = 2 /* MapBindingsPosition */;
143
+ /** @type {?} */
144
+ let i = start;
145
+ while (i < context.length) {
146
+ /** @type {?} */
147
+ const valuesCount = getValuesCount(context, i);
148
+ // the context may contain placeholder values which are populated ahead of time,
149
+ // but contain no actual binding values. In this situation there is no point in
150
+ // classifying this as an "entry" since no real data is stored here yet.
151
+ if (valuesCount) {
152
+ /** @type {?} */
153
+ const prop = getProp(context, i);
154
+ /** @type {?} */
155
+ const guardMask = getGuardMask(context, i);
156
+ /** @type {?} */
157
+ const defaultValue = getDefaultValue(context, i);
158
+ /** @type {?} */
159
+ const sanitizationRequired = isSanitizationRequired(context, i);
160
+ /** @type {?} */
161
+ const bindingsStartPosition = i + 3 /* BindingsStartOffset */;
162
+ /** @type {?} */
163
+ const sources = [];
164
+ for (let j = 0; j < valuesCount; j++) {
165
+ sources.push((/** @type {?} */ (context[bindingsStartPosition + j])));
166
+ }
167
+ entries[prop] = { prop, guardMask, sanitizationRequired, valuesCount, defaultValue, sources };
168
+ }
169
+ i += 3 /* BindingsStartOffset */ + valuesCount;
170
+ }
171
+ return entries;
172
+ }
173
+ }
174
+ if (false) {
175
+ /** @type {?} */
176
+ TStylingContextDebug.prototype.context;
177
+ }
178
+ /**
179
+ * A human-readable debug summary of the styling data present for a `DebugNode` instance.
180
+ *
181
+ * This class is designed to be used within testing code or when an
182
+ * application has `ngDevMode` activated.
183
+ */
184
+ export class NodeStylingDebug {
185
+ /**
186
+ * @param {?} context
187
+ * @param {?} _data
188
+ * @param {?=} _isClassBased
189
+ */
190
+ constructor(context, _data, _isClassBased) {
191
+ this.context = context;
192
+ this._data = _data;
193
+ this._isClassBased = _isClassBased;
194
+ this._sanitizer = null;
195
+ }
196
+ /**
197
+ * Overrides the sanitizer used to process styles.
198
+ * @param {?} sanitizer
199
+ * @return {?}
200
+ */
201
+ overrideSanitizer(sanitizer) { this._sanitizer = sanitizer; }
202
+ /**
203
+ * Returns a detailed summary of each styling entry in the context and
204
+ * what their runtime representation is.
205
+ *
206
+ * See `LStylingSummary`.
207
+ * @return {?}
208
+ */
209
+ get summary() {
210
+ /** @type {?} */
211
+ const entries = {};
212
+ this._mapValues((/**
213
+ * @param {?} prop
214
+ * @param {?} value
215
+ * @param {?} bindingIndex
216
+ * @return {?}
217
+ */
218
+ (prop, value, bindingIndex) => {
219
+ entries[prop] = { prop, value, bindingIndex };
220
+ }));
221
+ return entries;
222
+ }
223
+ /**
224
+ * Returns a key/value map of all the styles/classes that were last applied to the element.
225
+ * @return {?}
226
+ */
227
+ get values() {
228
+ /** @type {?} */
229
+ const entries = {};
230
+ this._mapValues((/**
231
+ * @param {?} prop
232
+ * @param {?} value
233
+ * @return {?}
234
+ */
235
+ (prop, value) => { entries[prop] = value; }));
236
+ return entries;
237
+ }
238
+ /**
239
+ * @private
240
+ * @param {?} fn
241
+ * @return {?}
242
+ */
243
+ _mapValues(fn) {
244
+ // there is no need to store/track an element instance. The
245
+ // element is only used when the styling algorithm attempts to
246
+ // style the value (and we mock out the stylingApplyFn anyway).
247
+ /** @type {?} */
248
+ const mockElement = (/** @type {?} */ ({}));
249
+ /** @type {?} */
250
+ const hasMaps = getValuesCount(this.context, 2 /* MapBindingsPosition */) > 0;
251
+ if (hasMaps) {
252
+ activeStylingMapFeature();
253
+ }
254
+ /** @type {?} */
255
+ const mapFn = (/**
256
+ * @param {?} renderer
257
+ * @param {?} element
258
+ * @param {?} prop
259
+ * @param {?} value
260
+ * @param {?} bindingIndex
261
+ * @return {?}
262
+ */
263
+ (renderer, element, prop, value, bindingIndex) => {
264
+ fn(prop, value, bindingIndex || null);
265
+ });
266
+ /** @type {?} */
267
+ const sanitizer = this._isClassBased ? null : (this._sanitizer ||
268
+ getCurrentOrLViewSanitizer((/** @type {?} */ (this._data))));
269
+ applyStyling(this.context, null, mockElement, this._data, true, mapFn, sanitizer);
270
+ }
271
+ }
272
+ if (false) {
273
+ /**
274
+ * @type {?}
275
+ * @private
276
+ */
277
+ NodeStylingDebug.prototype._sanitizer;
278
+ /** @type {?} */
279
+ NodeStylingDebug.prototype.context;
280
+ /**
281
+ * @type {?}
282
+ * @private
283
+ */
284
+ NodeStylingDebug.prototype._data;
285
+ /**
286
+ * @type {?}
287
+ * @private
288
+ */
289
+ NodeStylingDebug.prototype._isClassBased;
290
+ }
291
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"styling_debug.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/styling_next/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 {Sanitizer} from '../../sanitization/security';\nimport {StyleSanitizeFn} from '../../sanitization/style_sanitizer';\nimport {RElement} from '../interfaces/renderer';\nimport {LView, SANITIZER} from '../interfaces/view';\nimport {attachDebugObject} from '../util/debug_utils';\n\nimport {applyStyling} from './bindings';\nimport {ApplyStylingFn, LStylingData, TStylingContext, TStylingContextIndex} from './interfaces';\nimport {activeStylingMapFeature} from './map_based_bindings';\nimport {getCurrentStyleSanitizer} from './state';\nimport {getCurrentOrLViewSanitizer, getDefaultValue, getGuardMask, getProp, getValuesCount, isContextLocked, isMapBased, isSanitizationRequired} from './util';\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/**\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 LStylingSummary {\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 * A debug/testing-oriented summary of all styling entries for a `DebugNode` instance.\n */\nexport interface DebugStyling {\n  /** The associated TStylingContext instance */\n  context: TStylingContext;\n\n  /**\n   * A summarization of each style/class property\n   * present in the context.\n   */\n  summary: {[key: string]: LStylingSummary};\n\n  /**\n   * A key/value map of all styling properties and their\n   * runtime values.\n   */\n  values: {[key: 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 * A debug/testing-oriented summary of all styling entries within a `TStylingContext`.\n */\nexport interface TStylingTupleSummary {\n  /** The property (style or class property) that this tuple represents */\n  prop: string;\n\n  /** The total amount of styling entries apart of this tuple */\n  valuesCount: number;\n\n  /**\n   * The bit guard mask that is used to compare and protect against\n   * styling changes when and styling bindings update\n   */\n  guardMask: 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 * Instantiates and attaches an instance of `TStylingContextDebug` to the provided context.\n */\nexport function attachStylingDebugObject(context: TStylingContext) {\n  const debug = new TStylingContextDebug(context);\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 {\n  constructor(public readonly context: TStylingContext) {}\n\n  get isLocked() { return isContextLocked(this.context); }\n\n  /**\n   * Returns a detailed summary of each styling entry in the context.\n   *\n   * See `TStylingTupleSummary`.\n   */\n  get entries(): {[prop: string]: TStylingTupleSummary} {\n    const context = this.context;\n    const entries: {[prop: string]: TStylingTupleSummary} = {};\n    const start = TStylingContextIndex.MapBindingsPosition;\n    let i = start;\n    while (i < context.length) {\n      const valuesCount = getValuesCount(context, i);\n      // the context may contain placeholder values which are populated ahead of time,\n      // but contain no actual binding values. In this situation there is no point in\n      // classifying this as an \"entry\" since no real data is stored here yet.\n      if (valuesCount) {\n        const prop = getProp(context, i);\n        const guardMask = getGuardMask(context, i);\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        for (let j = 0; j < valuesCount; j++) {\n          sources.push(context[bindingsStartPosition + j] as number | string | null);\n        }\n\n        entries[prop] = {prop, guardMask, sanitizationRequired, valuesCount, defaultValue, sources};\n      }\n\n      i += TStylingContextIndex.BindingsStartOffset + valuesCount;\n    }\n    return entries;\n  }\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 DebugStyling {\n  private _sanitizer: StyleSanitizeFn|null = null;\n\n  constructor(\n      public context: TStylingContext, private _data: LStylingData,\n      private _isClassBased?: boolean) {}\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]: LStylingSummary} {\n    const entries: {[key: string]: LStylingSummary} = {};\n    this._mapValues((prop: string, value: any, bindingIndex: number | null) => {\n      entries[prop] = {prop, value, bindingIndex};\n    });\n    return entries;\n  }\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    this._mapValues((prop: string, value: any) => { entries[prop] = value; });\n    return entries;\n  }\n\n  private _mapValues(fn: (prop: string, value: any, 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 hasMaps = getValuesCount(this.context, TStylingContextIndex.MapBindingsPosition) > 0;\n    if (hasMaps) {\n      activeStylingMapFeature();\n    }\n\n    const mapFn: ApplyStylingFn =\n        (renderer: any, element: RElement, prop: string, value: any, bindingIndex: number) => {\n          fn(prop, value, bindingIndex || null);\n        };\n\n    const sanitizer = this._isClassBased ? null : (this._sanitizer ||\n                                                   getCurrentOrLViewSanitizer(this._data as LView));\n    applyStyling(this.context, null, mockElement, this._data, true, mapFn, sanitizer);\n  }\n}\n"]}
@@ -0,0 +1,259 @@
1
+ /**
2
+ * @fileoverview added by tsickle
3
+ * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
4
+ */
5
+ /**
6
+ * @license
7
+ * Copyright Google Inc. All Rights Reserved.
8
+ *
9
+ * Use of this source code is governed by an MIT-style license that can be
10
+ * found in the LICENSE file at https://angular.io/license
11
+ */
12
+ import { SecurityContext } from '../../sanitization/security';
13
+ import { SANITIZER } from '../interfaces/view';
14
+ import { getProp as getOldProp, getSinglePropIndexValue as getOldSinglePropIndexValue } from '../styling/class_and_style_bindings';
15
+ import { getCurrentStyleSanitizer, setCurrentStyleSanitizer } from './state';
16
+ /** @type {?} */
17
+ const MAP_BASED_ENTRY_PROP_NAME = '--MAP--';
18
+ /**
19
+ * Creates a new instance of the `TStylingContext`.
20
+ *
21
+ * This function will also pre-fill the context with data
22
+ * for map-based bindings.
23
+ * @return {?}
24
+ */
25
+ export function allocTStylingContext() {
26
+ // because map-based bindings deal with a dynamic set of values, there
27
+ // is no way to know ahead of time whether or not sanitization is required.
28
+ // For this reason the configuration will always mark sanitization as active
29
+ // (this means that when map-based values are applied then sanitization will
30
+ // be checked against each property).
31
+ /** @type {?} */
32
+ const mapBasedConfig = 1 /* SanitizationRequired */;
33
+ return [0 /* Initial */, 0, mapBasedConfig, 0, MAP_BASED_ENTRY_PROP_NAME];
34
+ }
35
+ /**
36
+ * Temporary function that allows for a string-based property name to be
37
+ * obtained from an index-based property identifier.
38
+ *
39
+ * This function will be removed once the new styling refactor code (which
40
+ * lives inside of `render3/styling_next/`) replaces the existing styling
41
+ * implementation.
42
+ * @param {?} stylingContext
43
+ * @param {?} offset
44
+ * @param {?} directiveIndex
45
+ * @param {?} isClassBased
46
+ * @return {?}
47
+ */
48
+ export function getBindingNameFromIndex(stylingContext, offset, directiveIndex, isClassBased) {
49
+ /** @type {?} */
50
+ const singleIndex = getOldSinglePropIndexValue(stylingContext, directiveIndex, offset, isClassBased);
51
+ return getOldProp(stylingContext, singleIndex);
52
+ }
53
+ /**
54
+ * @param {?} context
55
+ * @param {?} index
56
+ * @return {?}
57
+ */
58
+ export function updateContextDirectiveIndex(context, index) {
59
+ context[1 /* MaxDirectiveIndexPosition */] = index;
60
+ }
61
+ /**
62
+ * @param {?} context
63
+ * @return {?}
64
+ */
65
+ function getConfig(context) {
66
+ return context[0 /* ConfigPosition */];
67
+ }
68
+ /**
69
+ * @param {?} context
70
+ * @param {?} value
71
+ * @return {?}
72
+ */
73
+ export function setConfig(context, value) {
74
+ context[0 /* ConfigPosition */] = value;
75
+ }
76
+ /**
77
+ * @param {?} context
78
+ * @param {?} index
79
+ * @return {?}
80
+ */
81
+ export function getProp(context, index) {
82
+ return (/** @type {?} */ (context[index + 2 /* PropOffset */]));
83
+ }
84
+ /**
85
+ * @param {?} context
86
+ * @param {?} index
87
+ * @return {?}
88
+ */
89
+ function getPropConfig(context, index) {
90
+ return ((/** @type {?} */ (context[index + 0 /* ConfigAndGuardOffset */]))) &
91
+ 1 /* Mask */;
92
+ }
93
+ /**
94
+ * @param {?} context
95
+ * @param {?} index
96
+ * @return {?}
97
+ */
98
+ export function isSanitizationRequired(context, index) {
99
+ return (getPropConfig(context, index) & 1 /* SanitizationRequired */) > 0;
100
+ }
101
+ /**
102
+ * @param {?} context
103
+ * @param {?} index
104
+ * @return {?}
105
+ */
106
+ export function getGuardMask(context, index) {
107
+ /** @type {?} */
108
+ const configGuardValue = (/** @type {?} */ (context[index + 0 /* ConfigAndGuardOffset */]));
109
+ return configGuardValue >> 1 /* TotalBits */;
110
+ }
111
+ /**
112
+ * @param {?} context
113
+ * @param {?} index
114
+ * @param {?} maskValue
115
+ * @return {?}
116
+ */
117
+ export function setGuardMask(context, index, maskValue) {
118
+ /** @type {?} */
119
+ const config = getPropConfig(context, index);
120
+ /** @type {?} */
121
+ const guardMask = maskValue << 1 /* TotalBits */;
122
+ context[index + 0 /* ConfigAndGuardOffset */] = config | guardMask;
123
+ }
124
+ /**
125
+ * @param {?} context
126
+ * @param {?} index
127
+ * @return {?}
128
+ */
129
+ export function getValuesCount(context, index) {
130
+ return (/** @type {?} */ (context[index + 1 /* ValuesCountOffset */]));
131
+ }
132
+ /**
133
+ * @param {?} context
134
+ * @param {?} index
135
+ * @param {?} offset
136
+ * @return {?}
137
+ */
138
+ export function getBindingValue(context, index, offset) {
139
+ return (/** @type {?} */ (context[index + 3 /* BindingsStartOffset */ + offset]));
140
+ }
141
+ /**
142
+ * @param {?} context
143
+ * @param {?} index
144
+ * @return {?}
145
+ */
146
+ export function getDefaultValue(context, index) {
147
+ /** @type {?} */
148
+ const valuesCount = getValuesCount(context, index);
149
+ return (/** @type {?} */ (context[index + 3 /* BindingsStartOffset */ + valuesCount - 1]));
150
+ }
151
+ /**
152
+ * Temporary function which determines whether or not a context is
153
+ * allowed to be flushed based on the provided directive index.
154
+ * @param {?} context
155
+ * @param {?} index
156
+ * @return {?}
157
+ */
158
+ export function allowStylingFlush(context, index) {
159
+ return index === context[1 /* MaxDirectiveIndexPosition */];
160
+ }
161
+ /**
162
+ * @param {?} context
163
+ * @return {?}
164
+ */
165
+ export function lockContext(context) {
166
+ setConfig(context, getConfig(context) | 1 /* Locked */);
167
+ }
168
+ /**
169
+ * @param {?} context
170
+ * @return {?}
171
+ */
172
+ export function isContextLocked(context) {
173
+ return (getConfig(context) & 1 /* Locked */) > 0;
174
+ }
175
+ /**
176
+ * @param {?} context
177
+ * @return {?}
178
+ */
179
+ export function getPropValuesStartPosition(context) {
180
+ return 5 /* MapBindingsBindingsStartPosition */ +
181
+ context[3 /* MapBindingsValuesCountPosition */];
182
+ }
183
+ /**
184
+ * @param {?} prop
185
+ * @return {?}
186
+ */
187
+ export function isMapBased(prop) {
188
+ return prop === MAP_BASED_ENTRY_PROP_NAME;
189
+ }
190
+ /**
191
+ * @param {?} a
192
+ * @param {?} b
193
+ * @return {?}
194
+ */
195
+ export function hasValueChanged(a, b) {
196
+ /** @type {?} */
197
+ const compareValueA = Array.isArray(a) ? a[0 /* RawValuePosition */] : a;
198
+ /** @type {?} */
199
+ const compareValueB = Array.isArray(b) ? b[0 /* RawValuePosition */] : b;
200
+ return compareValueA !== compareValueB;
201
+ }
202
+ /**
203
+ * Determines whether the provided styling value is truthy or falsy.
204
+ * @param {?} value
205
+ * @return {?}
206
+ */
207
+ export function isStylingValueDefined(value) {
208
+ // the reason why null is compared against is because
209
+ // a CSS class value that is set to `false` must be
210
+ // respected (otherwise it would be treated as falsy).
211
+ // Empty string values are because developers usually
212
+ // set a value to an empty string to remove it.
213
+ return value != null && value !== '';
214
+ }
215
+ /**
216
+ * Returns the current style sanitizer function for the given view.
217
+ *
218
+ * The default style sanitizer (which lives inside of `LView`) will
219
+ * be returned depending on whether the `styleSanitizer` instruction
220
+ * was called or not prior to any styling instructions running.
221
+ * @param {?} lView
222
+ * @return {?}
223
+ */
224
+ export function getCurrentOrLViewSanitizer(lView) {
225
+ /** @type {?} */
226
+ const sanitizer = (/** @type {?} */ ((getCurrentStyleSanitizer() || lView[SANITIZER])));
227
+ if (sanitizer && typeof sanitizer !== 'function') {
228
+ setCurrentStyleSanitizer(sanitizer);
229
+ return sanitizeUsingSanitizerObject;
230
+ }
231
+ return sanitizer;
232
+ }
233
+ /**
234
+ * Style sanitization function that internally uses a `Sanitizer` instance to handle style
235
+ * sanitization.
236
+ * @type {?}
237
+ */
238
+ const sanitizeUsingSanitizerObject = (/**
239
+ * @param {?} prop
240
+ * @param {?} value
241
+ * @param {?} mode
242
+ * @return {?}
243
+ */
244
+ (prop, value, mode) => {
245
+ /** @type {?} */
246
+ const sanitizer = (/** @type {?} */ (getCurrentStyleSanitizer()));
247
+ if (sanitizer) {
248
+ if (mode & 2 /* SanitizeOnly */) {
249
+ return sanitizer.sanitize(SecurityContext.STYLE, value);
250
+ }
251
+ else {
252
+ return true;
253
+ }
254
+ }
255
+ return value;
256
+ });
257
+ const ɵ0 = sanitizeUsingSanitizerObject;
258
+ export { ɵ0 };
259
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"util.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/styling_next/util.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 {Sanitizer, SecurityContext} from '../../sanitization/security';\nimport {StyleSanitizeFn, StyleSanitizeMode} from '../../sanitization/style_sanitizer';\nimport {StylingContext} from '../interfaces/styling';\nimport {LView, SANITIZER} from '../interfaces/view';\nimport {getProp as getOldProp, getSinglePropIndexValue as getOldSinglePropIndexValue} from '../styling/class_and_style_bindings';\n\nimport {LStylingMap, LStylingMapIndex, TStylingConfigFlags, TStylingContext, TStylingContextIndex, TStylingContextPropConfigFlags} from './interfaces';\nimport {getCurrentStyleSanitizer, setCurrentStyleSanitizer} from './state';\n\nconst MAP_BASED_ENTRY_PROP_NAME = '--MAP--';\n\n/**\n * Creates a new instance of the `TStylingContext`.\n *\n * This function will also pre-fill the context with data\n * for map-based bindings.\n */\nexport function allocTStylingContext(): TStylingContext {\n  // because map-based bindings deal with a dynamic set of values, there\n  // is no way to know ahead of time whether or not sanitization is required.\n  // For this reason the configuration will always mark sanitization as active\n  // (this means that when map-based values are applied then sanitization will\n  // be checked against each property).\n  const mapBasedConfig = TStylingContextPropConfigFlags.SanitizationRequired;\n  return [TStylingConfigFlags.Initial, 0, mapBasedConfig, 0, MAP_BASED_ENTRY_PROP_NAME];\n}\n\n/**\n * Temporary function that allows for a string-based property name to be\n * obtained from an index-based property identifier.\n *\n * This function will be removed once the new styling refactor code (which\n * lives inside of `render3/styling_next/`) replaces the existing styling\n * implementation.\n */\nexport function getBindingNameFromIndex(\n    stylingContext: StylingContext, offset: number, directiveIndex: number, isClassBased: boolean) {\n  const singleIndex =\n      getOldSinglePropIndexValue(stylingContext, directiveIndex, offset, isClassBased);\n  return getOldProp(stylingContext, singleIndex);\n}\n\nexport function updateContextDirectiveIndex(context: TStylingContext, index: number) {\n  context[TStylingContextIndex.MaxDirectiveIndexPosition] = index;\n}\n\nfunction getConfig(context: TStylingContext) {\n  return context[TStylingContextIndex.ConfigPosition];\n}\n\nexport function setConfig(context: TStylingContext, value: number) {\n  context[TStylingContextIndex.ConfigPosition] = value;\n}\n\nexport function getProp(context: TStylingContext, index: number) {\n  return context[index + TStylingContextIndex.PropOffset] as string;\n}\n\nfunction getPropConfig(context: TStylingContext, index: number): number {\n  return (context[index + TStylingContextIndex.ConfigAndGuardOffset] as number) &\n      TStylingContextPropConfigFlags.Mask;\n}\n\nexport function isSanitizationRequired(context: TStylingContext, index: number) {\n  return (getPropConfig(context, index) & TStylingContextPropConfigFlags.SanitizationRequired) > 0;\n}\n\nexport function getGuardMask(context: TStylingContext, index: number) {\n  const configGuardValue = context[index + TStylingContextIndex.ConfigAndGuardOffset] as number;\n  return configGuardValue >> TStylingContextPropConfigFlags.TotalBits;\n}\n\nexport function setGuardMask(context: TStylingContext, index: number, maskValue: number) {\n  const config = getPropConfig(context, index);\n  const guardMask = maskValue << TStylingContextPropConfigFlags.TotalBits;\n  context[index + TStylingContextIndex.ConfigAndGuardOffset] = config | guardMask;\n}\n\nexport function getValuesCount(context: TStylingContext, index: number) {\n  return context[index + TStylingContextIndex.ValuesCountOffset] as number;\n}\n\nexport function getBindingValue(context: TStylingContext, index: number, offset: number) {\n  return context[index + TStylingContextIndex.BindingsStartOffset + offset] as number | string;\n}\n\nexport function getDefaultValue(context: TStylingContext, index: number): string|boolean|null {\n  const valuesCount = getValuesCount(context, index);\n  return context[index + TStylingContextIndex.BindingsStartOffset + valuesCount - 1] as string |\n      boolean | null;\n}\n\n/**\n * Temporary function which determines whether or not a context is\n * allowed to be flushed based on the provided directive index.\n */\nexport function allowStylingFlush(context: TStylingContext, index: number) {\n  return index === context[TStylingContextIndex.MaxDirectiveIndexPosition];\n}\n\nexport function lockContext(context: TStylingContext) {\n  setConfig(context, getConfig(context) | TStylingConfigFlags.Locked);\n}\n\nexport function isContextLocked(context: TStylingContext): boolean {\n  return (getConfig(context) & TStylingConfigFlags.Locked) > 0;\n}\n\nexport function getPropValuesStartPosition(context: TStylingContext) {\n  return TStylingContextIndex.MapBindingsBindingsStartPosition +\n      context[TStylingContextIndex.MapBindingsValuesCountPosition];\n}\n\nexport function isMapBased(prop: string) {\n  return prop === MAP_BASED_ENTRY_PROP_NAME;\n}\n\nexport function hasValueChanged(\n    a: LStylingMap | number | String | string | null | boolean | undefined | {},\n    b: LStylingMap | number | String | string | null | boolean | undefined | {}): boolean {\n  const compareValueA = Array.isArray(a) ? a[LStylingMapIndex.RawValuePosition] : a;\n  const compareValueB = Array.isArray(b) ? b[LStylingMapIndex.RawValuePosition] : b;\n  return compareValueA !== compareValueB;\n}\n\n/**\n * Determines whether the provided styling value is truthy or falsy.\n */\nexport function isStylingValueDefined(value: any) {\n  // the reason why null is compared against is because\n  // a CSS class value that is set to `false` must be\n  // respected (otherwise it would be treated as falsy).\n  // Empty string values are because developers usually\n  // set a value to an empty string to remove it.\n  return value != null && value !== '';\n}\n\n/**\n * Returns the current style sanitizer function for the given view.\n *\n * The default style sanitizer (which lives inside of `LView`) will\n * be returned depending on whether the `styleSanitizer` instruction\n * was called or not prior to any styling instructions running.\n */\nexport function getCurrentOrLViewSanitizer(lView: LView): StyleSanitizeFn|null {\n  const sanitizer: StyleSanitizeFn|null = (getCurrentStyleSanitizer() || lView[SANITIZER]) as any;\n  if (sanitizer && typeof sanitizer !== 'function') {\n    setCurrentStyleSanitizer(sanitizer);\n    return sanitizeUsingSanitizerObject;\n  }\n  return sanitizer;\n}\n\n/**\n * Style sanitization function that internally uses a `Sanitizer` instance to handle style\n * sanitization.\n */\nconst sanitizeUsingSanitizerObject: StyleSanitizeFn =\n    (prop: string, value: string, mode: StyleSanitizeMode) => {\n      const sanitizer = getCurrentStyleSanitizer() as Sanitizer;\n      if (sanitizer) {\n        if (mode & StyleSanitizeMode.SanitizeOnly) {\n          return sanitizer.sanitize(SecurityContext.STYLE, value);\n        } else {\n          return true;\n        }\n      }\n      return value;\n    };\n"]}
@@ -111,9 +111,10 @@ export function attrsStylingIndexOf(attrs, startIndex) {
111
111
  * attribute values in a `TAttributes` array are only the names of attributes,
112
112
  * and not name-value pairs.
113
113
  * @param {?} marker The attribute marker to test.
114
- * @return {?} true if the marker is a "name-only" marker (e.g. `Bindings` or `Template`).
114
+ * @return {?} true if the marker is a "name-only" marker (e.g. `Bindings`, `Template` or `I18n`).
115
115
  */
116
116
  export function isNameOnlyAttributeMarker(marker) {
117
- return marker === 3 /* Bindings */ || marker === 4 /* Template */;
117
+ return marker === 3 /* Bindings */ || marker === 4 /* Template */ ||
118
+ marker === 6 /* I18n */;
118
119
  }
119
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attrs_utils.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/util/attrs_utils.ts"],"names":[],"mappings":";;;;AASA,OAAO,EAAgC,oBAAoB,EAAC,MAAM,wBAAwB,CAAC;AAC3F,OAAO,EAAC,QAAQ,EAAC,MAAM,oBAAoB,CAAC;AAC5C,OAAO,EAAC,QAAQ,EAAC,MAAM,UAAU,CAAC;AAClC,OAAO,EAAC,eAAe,EAAC,MAAM,iBAAiB,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA+BhD,MAAM,UAAU,eAAe,CAAC,MAAgB,EAAE,KAAkB;;UAC5D,QAAQ,GAAG,QAAQ,EAAE,CAAC,QAAQ,CAAC;;UAC/B,MAAM,GAAG,oBAAoB,CAAC,QAAQ,CAAC;;QAEzC,CAAC,GAAG,CAAC;IACT,OAAO,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE;;cACjB,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC;QACtB,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;YAC7B,wEAAwE;YACxE,+CAA+C;YAC/C,IAAI,KAAK,yBAAiC,EAAE;gBAC1C,MAAM;aACP;YAED,mDAAmD;YACnD,mCAAmC;YACnC,CAAC,EAAE,CAAC;;kBAEE,YAAY,GAAG,mBAAA,KAAK,CAAC,CAAC,EAAE,CAAC,EAAU;;kBACnC,QAAQ,GAAG,mBAAA,KAAK,CAAC,CAAC,EAAE,CAAC,EAAU;;kBAC/B,OAAO,GAAG,mBAAA,KAAK,CAAC,CAAC,EAAE,CAAC,EAAU;YACpC,SAAS,IAAI,SAAS,CAAC,oBAAoB,EAAE,CAAC;YAC9C,MAAM,CAAC,CAAC;gBACJ,CAAC,mBAAA,QAAQ,EAAuB,CAAC,CAAC,YAAY,CAAC,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC,CAAC;gBACzF,MAAM,CAAC,cAAc,CAAC,YAAY,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;SAC5D;aAAM;;;kBAEC,QAAQ,GAAG,mBAAA,KAAK,EAAU;;kBAC1B,OAAO,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;YAC1B,sBAAsB;YACtB,SAAS,IAAI,SAAS,CAAC,oBAAoB,EAAE,CAAC;YAC9C,IAAI,eAAe,CAAC,QAAQ,CAAC,EAAE;gBAC7B,IAAI,MAAM,EAAE;oBACV,CAAC,mBAAA,QAAQ,EAAuB,CAAC,CAAC,WAAW,CAAC,MAAM,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;iBAC1E;aACF;iBAAM;gBACL,MAAM,CAAC,CAAC;oBACJ,CAAC,mBAAA,QAAQ,EAAuB,CAAC;yBAC5B,YAAY,CAAC,MAAM,EAAE,mBAAA,QAAQ,EAAU,EAAE,mBAAA,OAAO,EAAU,CAAC,CAAC,CAAC;oBAClE,MAAM,CAAC,YAAY,CAAC,mBAAA,QAAQ,EAAU,EAAE,mBAAA,OAAO,EAAU,CAAC,CAAC;aAChE;YACD,CAAC,EAAE,CAAC;SACL;KACF;IAED,8EAA8E;IAC9E,+EAA+E;IAC/E,iFAAiF;IACjF,iBAAiB;IACjB,OAAO,CAAC,CAAC;AACX,CAAC;;;;;;AAGD,MAAM,UAAU,mBAAmB,CAAC,KAAkB,EAAE,UAAkB;IACxE,KAAK,IAAI,CAAC,GAAG,UAAU,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;;cACxC,GAAG,GAAG,KAAK,CAAC,CAAC,CAAC;QACpB,IAAI,GAAG,oBAA4B,IAAI,GAAG,mBAA2B,EAAE;YACrE,OAAO,CAAC,CAAC;SACV;KACF;IACD,OAAO,CAAC,CAAC,CAAC;AACZ,CAAC;;;;;;;;AASD,MAAM,UAAU,yBAAyB,CAAC,MAA8C;IACtF,OAAO,MAAM,qBAA6B,IAAI,MAAM,qBAA6B,CAAC;AACpF,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 {AttributeMarker, TAttributes} from '../interfaces/node';\nimport {CssSelector} from '../interfaces/projection';\nimport {ProceduralRenderer3, RElement, isProceduralRenderer} from '../interfaces/renderer';\nimport {RENDERER} from '../interfaces/view';\nimport {getLView} from '../state';\nimport {isAnimationProp} from '../styling/util';\n\n\n\n/**\n * Assigns all attribute values to the provided element via the inferred renderer.\n *\n * This function accepts two forms of attribute entries:\n *\n * default: (key, value):\n *  attrs = [key1, value1, key2, value2]\n *\n * namespaced: (NAMESPACE_MARKER, uri, name, value)\n *  attrs = [NAMESPACE_MARKER, uri, name, value, NAMESPACE_MARKER, uri, name, value]\n *\n * The `attrs` array can contain a mix of both the default and namespaced entries.\n * The \"default\" values are set without a marker, but if the function comes across\n * a marker value then it will attempt to set a namespaced value. If the marker is\n * not of a namespaced value then the function will quit and return the index value\n * where it stopped during the iteration of the attrs array.\n *\n * See [AttributeMarker] to understand what the namespace marker value is.\n *\n * Note that this instruction does not support assigning style and class values to\n * an element. See `elementStart` and `elementHostAttrs` to learn how styling values\n * are applied to an element.\n *\n * @param native The element that the attributes will be assigned to\n * @param attrs The attribute array of values that will be assigned to the element\n * @returns the index value that was last accessed in the attributes array\n */\nexport function setUpAttributes(native: RElement, attrs: TAttributes): number {\n  const renderer = getLView()[RENDERER];\n  const isProc = isProceduralRenderer(renderer);\n\n  let i = 0;\n  while (i < attrs.length) {\n    const value = attrs[i];\n    if (typeof value === 'number') {\n      // only namespaces are supported. Other value types (such as style/class\n      // entries) are not supported in this function.\n      if (value !== AttributeMarker.NamespaceURI) {\n        break;\n      }\n\n      // we just landed on the marker value ... therefore\n      // we should skip to the next entry\n      i++;\n\n      const namespaceURI = attrs[i++] as string;\n      const attrName = attrs[i++] as string;\n      const attrVal = attrs[i++] as string;\n      ngDevMode && ngDevMode.rendererSetAttribute++;\n      isProc ?\n          (renderer as ProceduralRenderer3).setAttribute(native, attrName, attrVal, namespaceURI) :\n          native.setAttributeNS(namespaceURI, attrName, attrVal);\n    } else {\n      // attrName is string;\n      const attrName = value as string;\n      const attrVal = attrs[++i];\n      // Standard attributes\n      ngDevMode && ngDevMode.rendererSetAttribute++;\n      if (isAnimationProp(attrName)) {\n        if (isProc) {\n          (renderer as ProceduralRenderer3).setProperty(native, attrName, attrVal);\n        }\n      } else {\n        isProc ?\n            (renderer as ProceduralRenderer3)\n                .setAttribute(native, attrName as string, attrVal as string) :\n            native.setAttribute(attrName as string, attrVal as string);\n      }\n      i++;\n    }\n  }\n\n  // another piece of code may iterate over the same attributes array. Therefore\n  // it may be helpful to return the exact spot where the attributes array exited\n  // whether by running into an unsupported marker or if all the static values were\n  // iterated over.\n  return i;\n}\n\n\nexport function attrsStylingIndexOf(attrs: TAttributes, startIndex: number): number {\n  for (let i = startIndex; i < attrs.length; i++) {\n    const val = attrs[i];\n    if (val === AttributeMarker.Classes || val === AttributeMarker.Styles) {\n      return i;\n    }\n  }\n  return -1;\n}\n\n/**\n * Test whether the given value is a marker that indicates that the following\n * attribute values in a `TAttributes` array are only the names of attributes,\n * and not name-value pairs.\n * @param marker The attribute marker to test.\n * @returns true if the marker is a \"name-only\" marker (e.g. `Bindings` or `Template`).\n */\nexport function isNameOnlyAttributeMarker(marker: string | AttributeMarker | CssSelector) {\n  return marker === AttributeMarker.Bindings || marker === AttributeMarker.Template;\n}\n"]}
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attrs_utils.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/util/attrs_utils.ts"],"names":[],"mappings":";;;;AASA,OAAO,EAAgC,oBAAoB,EAAC,MAAM,wBAAwB,CAAC;AAC3F,OAAO,EAAC,QAAQ,EAAC,MAAM,oBAAoB,CAAC;AAC5C,OAAO,EAAC,QAAQ,EAAC,MAAM,UAAU,CAAC;AAClC,OAAO,EAAC,eAAe,EAAC,MAAM,iBAAiB,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA+BhD,MAAM,UAAU,eAAe,CAAC,MAAgB,EAAE,KAAkB;;UAC5D,QAAQ,GAAG,QAAQ,EAAE,CAAC,QAAQ,CAAC;;UAC/B,MAAM,GAAG,oBAAoB,CAAC,QAAQ,CAAC;;QAEzC,CAAC,GAAG,CAAC;IACT,OAAO,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE;;cACjB,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC;QACtB,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;YAC7B,wEAAwE;YACxE,+CAA+C;YAC/C,IAAI,KAAK,yBAAiC,EAAE;gBAC1C,MAAM;aACP;YAED,mDAAmD;YACnD,mCAAmC;YACnC,CAAC,EAAE,CAAC;;kBAEE,YAAY,GAAG,mBAAA,KAAK,CAAC,CAAC,EAAE,CAAC,EAAU;;kBACnC,QAAQ,GAAG,mBAAA,KAAK,CAAC,CAAC,EAAE,CAAC,EAAU;;kBAC/B,OAAO,GAAG,mBAAA,KAAK,CAAC,CAAC,EAAE,CAAC,EAAU;YACpC,SAAS,IAAI,SAAS,CAAC,oBAAoB,EAAE,CAAC;YAC9C,MAAM,CAAC,CAAC;gBACJ,CAAC,mBAAA,QAAQ,EAAuB,CAAC,CAAC,YAAY,CAAC,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC,CAAC;gBACzF,MAAM,CAAC,cAAc,CAAC,YAAY,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;SAC5D;aAAM;;;kBAEC,QAAQ,GAAG,mBAAA,KAAK,EAAU;;kBAC1B,OAAO,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;YAC1B,sBAAsB;YACtB,SAAS,IAAI,SAAS,CAAC,oBAAoB,EAAE,CAAC;YAC9C,IAAI,eAAe,CAAC,QAAQ,CAAC,EAAE;gBAC7B,IAAI,MAAM,EAAE;oBACV,CAAC,mBAAA,QAAQ,EAAuB,CAAC,CAAC,WAAW,CAAC,MAAM,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;iBAC1E;aACF;iBAAM;gBACL,MAAM,CAAC,CAAC;oBACJ,CAAC,mBAAA,QAAQ,EAAuB,CAAC;yBAC5B,YAAY,CAAC,MAAM,EAAE,mBAAA,QAAQ,EAAU,EAAE,mBAAA,OAAO,EAAU,CAAC,CAAC,CAAC;oBAClE,MAAM,CAAC,YAAY,CAAC,mBAAA,QAAQ,EAAU,EAAE,mBAAA,OAAO,EAAU,CAAC,CAAC;aAChE;YACD,CAAC,EAAE,CAAC;SACL;KACF;IAED,8EAA8E;IAC9E,+EAA+E;IAC/E,iFAAiF;IACjF,iBAAiB;IACjB,OAAO,CAAC,CAAC;AACX,CAAC;;;;;;AAGD,MAAM,UAAU,mBAAmB,CAAC,KAAkB,EAAE,UAAkB;IACxE,KAAK,IAAI,CAAC,GAAG,UAAU,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;;cACxC,GAAG,GAAG,KAAK,CAAC,CAAC,CAAC;QACpB,IAAI,GAAG,oBAA4B,IAAI,GAAG,mBAA2B,EAAE;YACrE,OAAO,CAAC,CAAC;SACV;KACF;IACD,OAAO,CAAC,CAAC,CAAC;AACZ,CAAC;;;;;;;;AASD,MAAM,UAAU,yBAAyB,CAAC,MAA8C;IACtF,OAAO,MAAM,qBAA6B,IAAI,MAAM,qBAA6B;QAC7E,MAAM,iBAAyB,CAAC;AACtC,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 {AttributeMarker, TAttributes} from '../interfaces/node';\nimport {CssSelector} from '../interfaces/projection';\nimport {ProceduralRenderer3, RElement, isProceduralRenderer} from '../interfaces/renderer';\nimport {RENDERER} from '../interfaces/view';\nimport {getLView} from '../state';\nimport {isAnimationProp} from '../styling/util';\n\n\n\n/**\n * Assigns all attribute values to the provided element via the inferred renderer.\n *\n * This function accepts two forms of attribute entries:\n *\n * default: (key, value):\n *  attrs = [key1, value1, key2, value2]\n *\n * namespaced: (NAMESPACE_MARKER, uri, name, value)\n *  attrs = [NAMESPACE_MARKER, uri, name, value, NAMESPACE_MARKER, uri, name, value]\n *\n * The `attrs` array can contain a mix of both the default and namespaced entries.\n * The \"default\" values are set without a marker, but if the function comes across\n * a marker value then it will attempt to set a namespaced value. If the marker is\n * not of a namespaced value then the function will quit and return the index value\n * where it stopped during the iteration of the attrs array.\n *\n * See [AttributeMarker] to understand what the namespace marker value is.\n *\n * Note that this instruction does not support assigning style and class values to\n * an element. See `elementStart` and `elementHostAttrs` to learn how styling values\n * are applied to an element.\n *\n * @param native The element that the attributes will be assigned to\n * @param attrs The attribute array of values that will be assigned to the element\n * @returns the index value that was last accessed in the attributes array\n */\nexport function setUpAttributes(native: RElement, attrs: TAttributes): number {\n  const renderer = getLView()[RENDERER];\n  const isProc = isProceduralRenderer(renderer);\n\n  let i = 0;\n  while (i < attrs.length) {\n    const value = attrs[i];\n    if (typeof value === 'number') {\n      // only namespaces are supported. Other value types (such as style/class\n      // entries) are not supported in this function.\n      if (value !== AttributeMarker.NamespaceURI) {\n        break;\n      }\n\n      // we just landed on the marker value ... therefore\n      // we should skip to the next entry\n      i++;\n\n      const namespaceURI = attrs[i++] as string;\n      const attrName = attrs[i++] as string;\n      const attrVal = attrs[i++] as string;\n      ngDevMode && ngDevMode.rendererSetAttribute++;\n      isProc ?\n          (renderer as ProceduralRenderer3).setAttribute(native, attrName, attrVal, namespaceURI) :\n          native.setAttributeNS(namespaceURI, attrName, attrVal);\n    } else {\n      // attrName is string;\n      const attrName = value as string;\n      const attrVal = attrs[++i];\n      // Standard attributes\n      ngDevMode && ngDevMode.rendererSetAttribute++;\n      if (isAnimationProp(attrName)) {\n        if (isProc) {\n          (renderer as ProceduralRenderer3).setProperty(native, attrName, attrVal);\n        }\n      } else {\n        isProc ?\n            (renderer as ProceduralRenderer3)\n                .setAttribute(native, attrName as string, attrVal as string) :\n            native.setAttribute(attrName as string, attrVal as string);\n      }\n      i++;\n    }\n  }\n\n  // another piece of code may iterate over the same attributes array. Therefore\n  // it may be helpful to return the exact spot where the attributes array exited\n  // whether by running into an unsupported marker or if all the static values were\n  // iterated over.\n  return i;\n}\n\n\nexport function attrsStylingIndexOf(attrs: TAttributes, startIndex: number): number {\n  for (let i = startIndex; i < attrs.length; i++) {\n    const val = attrs[i];\n    if (val === AttributeMarker.Classes || val === AttributeMarker.Styles) {\n      return i;\n    }\n  }\n  return -1;\n}\n\n/**\n * Test whether the given value is a marker that indicates that the following\n * attribute values in a `TAttributes` array are only the names of attributes,\n * and not name-value pairs.\n * @param marker The attribute marker to test.\n * @returns true if the marker is a \"name-only\" marker (e.g. `Bindings`, `Template` or `I18n`).\n */\nexport function isNameOnlyAttributeMarker(marker: string | AttributeMarker | CssSelector) {\n  return marker === AttributeMarker.Bindings || marker === AttributeMarker.Template ||\n      marker === AttributeMarker.I18n;\n}\n"]}