@angular/core 8.0.0 → 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.
- package/bundles/core-testing.umd.js +35 -9
- package/bundles/core-testing.umd.js.map +1 -1
- package/bundles/core-testing.umd.min.js +10 -10
- package/bundles/core-testing.umd.min.js.map +1 -1
- package/bundles/core.umd.js +11356 -9352
- package/bundles/core.umd.js.map +1 -1
- package/bundles/core.umd.min.js +201 -139
- package/bundles/core.umd.min.js.map +1 -1
- package/core.d.ts +1302 -404
- package/core.metadata.json +1 -1
- package/esm2015/core.js +2 -3
- package/esm2015/index.js +2 -2
- package/esm2015/public_api.js +2 -2
- package/esm2015/src/application_ref.js +7 -1
- package/esm2015/src/codegen_private_exports.js +2 -2
- package/esm2015/src/compiler/compiler_facade_interface.js +1 -1
- package/esm2015/src/core.js +4 -4
- package/esm2015/src/core_private_export.js +3 -1
- package/esm2015/src/core_render3_private_export.js +5 -3
- package/esm2015/src/debug/debug_node.js +4 -4
- package/esm2015/src/di/index.js +3 -3
- package/esm2015/src/di/injector.js +24 -96
- package/esm2015/src/di/injector_compatibility.js +103 -6
- package/esm2015/src/di/interface/defs.js +24 -3
- package/esm2015/src/di/r3_injector.js +82 -49
- package/esm2015/src/di/reflective_injector.js +3 -2
- package/esm2015/src/di.js +1 -1
- package/esm2015/src/i18n/locale_data.js +61 -0
- package/esm2015/src/i18n/locale_data_api.js +53 -0
- package/esm2015/src/i18n/locale_en.js +51 -0
- package/esm2015/src/i18n/localization.js +37 -0
- package/esm2015/src/linker/ng_module_factory_loader.js +4 -52
- package/esm2015/src/linker/ng_module_factory_registration.js +83 -0
- package/esm2015/src/metadata/ng_module.js +6 -1
- package/esm2015/src/metadata/resource_loading.js +2 -2
- package/esm2015/src/reflection/reflection_capabilities.js +14 -3
- package/esm2015/src/render3/assert.js +3 -2
- package/esm2015/src/render3/component.js +11 -5
- package/esm2015/src/render3/debug.js +23 -15
- package/esm2015/src/render3/definition.js +12 -2
- package/esm2015/src/render3/errors.js +29 -1
- package/esm2015/src/render3/features/inherit_definition_feature.js +51 -37
- package/esm2015/src/render3/fields.js +3 -1
- package/esm2015/src/render3/i18n.js +76 -465
- package/esm2015/src/render3/index.js +3 -3
- package/esm2015/src/render3/instructions/all.js +9 -4
- package/esm2015/src/render3/instructions/attribute.js +28 -0
- package/esm2015/src/render3/instructions/attribute_interpolation.js +376 -0
- package/esm2015/src/render3/instructions/container.js +17 -16
- package/esm2015/src/render3/instructions/element.js +57 -35
- package/esm2015/src/render3/instructions/element_container.js +9 -8
- package/esm2015/src/render3/instructions/embedded_view.js +9 -12
- package/esm2015/src/render3/instructions/interpolation.js +375 -0
- package/esm2015/src/render3/instructions/listener.js +3 -2
- package/esm2015/src/render3/instructions/projection.js +6 -6
- package/esm2015/src/render3/instructions/property.js +10 -4
- package/esm2015/src/render3/instructions/property_interpolation.js +49 -382
- package/esm2015/src/render3/instructions/shared.js +82 -118
- package/esm2015/src/render3/instructions/styling.js +189 -236
- package/esm2015/src/render3/instructions/text.js +8 -7
- package/esm2015/src/render3/instructions/text_interpolation.js +357 -0
- package/esm2015/src/render3/interfaces/container.js +9 -5
- package/esm2015/src/render3/interfaces/definition.js +12 -6
- package/esm2015/src/render3/interfaces/node.js +20 -8
- package/esm2015/src/render3/interfaces/styling.js +16 -15
- package/esm2015/src/render3/interfaces/view.js +2 -2
- package/esm2015/src/render3/jit/directive.js +14 -5
- package/esm2015/src/render3/jit/environment.js +30 -15
- package/esm2015/src/render3/jit/module.js +38 -19
- package/esm2015/src/render3/ng_module_ref.js +39 -3
- package/esm2015/src/render3/node_manipulation.js +45 -43
- package/esm2015/src/render3/node_selector_matcher.js +14 -13
- package/esm2015/src/render3/query.js +77 -61
- package/esm2015/src/render3/state.js +33 -6
- package/esm2015/src/render3/styling/class_and_style_bindings.js +91 -79
- package/esm2015/src/render3/styling/host_instructions_queue.js +8 -5
- package/esm2015/src/render3/styling/shared.js +2 -2
- package/esm2015/src/render3/styling/util.js +2 -2
- package/esm2015/src/render3/styling_next/bindings.js +602 -0
- package/esm2015/src/render3/styling_next/instructions.js +366 -0
- package/esm2015/src/render3/styling_next/interfaces.js +374 -0
- package/esm2015/src/render3/styling_next/map_based_bindings.js +408 -0
- package/esm2015/src/render3/styling_next/state.js +51 -0
- package/esm2015/src/render3/styling_next/styling_debug.js +291 -0
- package/esm2015/src/render3/styling_next/util.js +259 -0
- package/esm2015/src/render3/util/attrs_utils.js +4 -3
- package/esm2015/src/render3/util/debug_utils.js +18 -0
- package/esm2015/src/render3/util/view_traversal_utils.js +2 -2
- package/esm2015/src/render3/view_engine_compatibility.js +24 -10
- package/esm2015/src/sanitization/sanitization.js +17 -7
- package/esm2015/src/sanitization/style_sanitizer.js +11 -1
- package/esm2015/src/util/ng_dev_mode.js +7 -3
- package/esm2015/src/version.js +1 -1
- package/esm2015/src/view/ng_module.js +3 -3
- package/esm2015/src/view/util.js +2 -2
- package/esm2015/testing/src/r3_test_bed_compiler.js +44 -12
- package/esm5/core.js +2 -3
- package/esm5/src/application_ref.js +6 -1
- package/esm5/src/codegen_private_exports.js +2 -2
- package/esm5/src/compiler/compiler_facade_interface.js +1 -1
- package/esm5/src/core_private_export.js +3 -1
- package/esm5/src/core_render3_private_export.js +5 -3
- package/esm5/src/debug/debug_node.js +4 -4
- package/esm5/src/di/index.js +3 -3
- package/esm5/src/di/injector.js +14 -74
- package/esm5/src/di/injector_compatibility.js +77 -6
- package/esm5/src/di/interface/defs.js +24 -3
- package/esm5/src/di/r3_injector.js +60 -37
- package/esm5/src/di/reflective_injector.js +3 -2
- package/esm5/src/i18n/locale_data.js +38 -0
- package/esm5/src/i18n/locale_data_api.js +46 -0
- package/esm5/src/i18n/locale_en.js +39 -0
- package/esm5/src/i18n/localization.js +29 -0
- package/esm5/src/linker/ng_module_factory_loader.js +4 -32
- package/esm5/src/linker/ng_module_factory_registration.js +50 -0
- package/esm5/src/metadata/ng_module.js +1 -1
- package/esm5/src/metadata/resource_loading.js +2 -2
- package/esm5/src/reflection/reflection_capabilities.js +14 -3
- package/esm5/src/render3/assert.js +2 -1
- package/esm5/src/render3/component.js +10 -4
- package/esm5/src/render3/debug.js +17 -10
- package/esm5/src/render3/definition.js +8 -2
- package/esm5/src/render3/errors.js +14 -1
- package/esm5/src/render3/features/inherit_definition_feature.js +41 -36
- package/esm5/src/render3/fields.js +2 -1
- package/esm5/src/render3/i18n.js +67 -437
- package/esm5/src/render3/index.js +3 -3
- package/esm5/src/render3/instructions/all.js +6 -1
- package/esm5/src/render3/instructions/attribute.js +22 -0
- package/esm5/src/render3/instructions/attribute_interpolation.js +346 -0
- package/esm5/src/render3/instructions/container.js +16 -15
- package/esm5/src/render3/instructions/element.js +43 -32
- package/esm5/src/render3/instructions/element_container.js +9 -8
- package/esm5/src/render3/instructions/embedded_view.js +8 -11
- package/esm5/src/render3/instructions/interpolation.js +243 -0
- package/esm5/src/render3/instructions/listener.js +3 -2
- package/esm5/src/render3/instructions/projection.js +6 -6
- package/esm5/src/render3/instructions/property.js +10 -4
- package/esm5/src/render3/instructions/property_interpolation.js +40 -254
- package/esm5/src/render3/instructions/shared.js +70 -105
- package/esm5/src/render3/instructions/styling.js +167 -209
- package/esm5/src/render3/instructions/text.js +8 -7
- package/esm5/src/render3/instructions/text_interpolation.js +264 -0
- package/esm5/src/render3/interfaces/container.js +8 -2
- package/esm5/src/render3/interfaces/definition.js +1 -1
- package/esm5/src/render3/interfaces/node.js +1 -8
- package/esm5/src/render3/interfaces/styling.js +2 -2
- package/esm5/src/render3/interfaces/view.js +1 -1
- package/esm5/src/render3/jit/directive.js +12 -5
- package/esm5/src/render3/jit/environment.js +30 -15
- package/esm5/src/render3/jit/module.js +23 -18
- package/esm5/src/render3/ng_module_ref.js +37 -3
- package/esm5/src/render3/node_manipulation.js +39 -38
- package/esm5/src/render3/node_selector_matcher.js +14 -13
- package/esm5/src/render3/query.js +75 -53
- package/esm5/src/render3/state.js +29 -5
- package/esm5/src/render3/styling/class_and_style_bindings.js +79 -65
- package/esm5/src/render3/styling/host_instructions_queue.js +6 -3
- package/esm5/src/render3/styling/shared.js +2 -2
- package/esm5/src/render3/styling/util.js +2 -2
- package/esm5/src/render3/styling_next/bindings.js +446 -0
- package/esm5/src/render3/styling_next/instructions.js +277 -0
- package/esm5/src/render3/styling_next/interfaces.js +1 -0
- package/esm5/src/render3/styling_next/map_based_bindings.js +324 -0
- package/esm5/src/render3/styling_next/state.js +23 -0
- package/esm5/src/render3/styling_next/styling_debug.js +130 -0
- package/esm5/src/render3/styling_next/util.js +147 -0
- package/esm5/src/render3/util/attrs_utils.js +4 -3
- package/esm5/src/render3/util/debug_utils.js +11 -0
- package/esm5/src/render3/util/view_traversal_utils.js +2 -2
- package/esm5/src/render3/view_engine_compatibility.js +23 -10
- package/esm5/src/sanitization/sanitization.js +14 -6
- package/esm5/src/sanitization/style_sanitizer.js +1 -1
- package/esm5/src/util/ng_dev_mode.js +7 -3
- package/esm5/src/version.js +1 -1
- package/esm5/src/view/ng_module.js +3 -3
- package/esm5/src/view/util.js +2 -2
- package/esm5/testing/src/r3_test_bed_compiler.js +37 -11
- package/fesm2015/core.js +13481 -10733
- package/fesm2015/core.js.map +1 -1
- package/fesm2015/testing.js +43 -11
- package/fesm2015/testing.js.map +1 -1
- package/fesm5/core.js +11255 -9269
- package/fesm5/core.js.map +1 -1
- package/fesm5/testing.js +36 -10
- package/fesm5/testing.js.map +1 -1
- package/package.json +1 -1
- package/schematics/migrations/template-var-assignment/index.js +2 -2
- package/src/r3_symbols.d.ts +5 -1
- package/testing/testing.d.ts +1 -1
- 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 `
|
|
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,
|
|
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"]}
|