@angular/core 9.0.0-rc.9 → 9.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/core-testing.umd.js +10 -9
- package/bundles/core-testing.umd.js.map +1 -1
- package/bundles/core-testing.umd.min.js +6 -6
- package/bundles/core-testing.umd.min.js.map +1 -1
- package/bundles/core.umd.js +3619 -3914
- package/bundles/core.umd.js.map +1 -1
- package/bundles/core.umd.min.js +182 -175
- package/bundles/core.umd.min.js.map +1 -1
- package/core.d.ts +483 -651
- package/core.metadata.json +1 -1
- package/esm2015/core.js +17 -17
- package/esm2015/index.js +2 -2
- package/esm2015/public_api.js +2 -2
- package/esm2015/src/application_ref.js +7 -7
- package/esm2015/src/core.js +3 -3
- package/esm2015/src/core_private_export.js +7 -7
- package/esm2015/src/core_render3_private_export.js +2 -2
- package/esm2015/src/debug/debug_node.js +44 -12
- package/esm2015/src/i18n/locale_data_api.js +1 -2
- package/esm2015/src/interface/type.js +1 -1
- package/esm2015/src/metadata/ng_module.js +1 -1
- package/esm2015/src/render/api.js +4 -1
- package/esm2015/src/render3/assert.js +9 -1
- package/esm2015/src/render3/bindings.js +16 -5
- package/esm2015/src/render3/component.js +54 -25
- package/esm2015/src/render3/component_ref.js +11 -15
- package/esm2015/src/render3/definition.js +3 -1
- package/esm2015/src/render3/di.js +3 -4
- package/esm2015/src/render3/di_setup.js +5 -7
- package/esm2015/src/render3/errors.js +3 -1
- package/esm2015/src/render3/features/inherit_definition_feature.js +41 -13
- package/esm2015/src/render3/features/ng_onchanges_feature.js +2 -2
- package/esm2015/src/render3/global_utils_api.js +3 -3
- package/esm2015/src/render3/i18n.js +60 -56
- package/esm2015/src/render3/index.js +2 -2
- package/esm2015/src/render3/instructions/advance.js +10 -11
- package/esm2015/src/render3/instructions/all.js +4 -5
- package/esm2015/src/render3/instructions/attribute.js +6 -6
- package/esm2015/src/render3/instructions/attribute_interpolation.js +40 -21
- package/esm2015/src/render3/instructions/change_detection.js +8 -23
- package/esm2015/src/render3/instructions/class_map_interpolation.js +13 -12
- package/esm2015/src/render3/instructions/container.js +15 -12
- package/esm2015/src/render3/instructions/element.js +40 -127
- package/esm2015/src/render3/instructions/element_container.js +8 -10
- package/esm2015/src/render3/instructions/embedded_view.js +7 -7
- package/esm2015/src/render3/instructions/host_property.js +10 -7
- package/esm2015/src/render3/instructions/listener.js +18 -16
- package/esm2015/src/render3/instructions/lview_debug.js +160 -23
- package/esm2015/src/render3/instructions/projection.js +7 -5
- package/esm2015/src/render3/instructions/property.js +27 -6
- package/esm2015/src/render3/instructions/property_interpolation.js +40 -22
- package/esm2015/src/render3/instructions/shared.js +267 -240
- package/esm2015/src/render3/instructions/storage.js +6 -8
- package/esm2015/src/render3/instructions/style_prop_interpolation.js +12 -12
- package/esm2015/src/render3/instructions/styling.js +731 -475
- package/esm2015/src/render3/instructions/text.js +5 -5
- package/esm2015/src/render3/interfaces/definition.js +41 -1
- package/esm2015/src/render3/interfaces/node.js +160 -115
- package/esm2015/src/render3/interfaces/styling.js +183 -375
- package/esm2015/src/render3/interfaces/view.js +10 -2
- package/esm2015/src/render3/jit/environment.js +1 -3
- package/esm2015/src/render3/node_manipulation.js +177 -57
- package/esm2015/src/render3/node_selector_matcher.js +39 -24
- package/esm2015/src/render3/node_util.js +12 -7
- package/esm2015/src/render3/pipe.js +4 -6
- package/esm2015/src/render3/query.js +32 -26
- package/esm2015/src/render3/state.js +54 -183
- package/esm2015/src/render3/styling/class_differ.js +47 -0
- package/esm2015/src/render3/styling/static_styling.js +54 -0
- package/esm2015/src/render3/styling/style_binding_list.js +437 -0
- package/esm2015/src/render3/styling/styling_parser.js +336 -0
- package/esm2015/src/render3/tokens.js +2 -2
- package/esm2015/src/render3/util/attrs_utils.js +125 -2
- package/esm2015/src/render3/util/change_detection_utils.js +33 -0
- package/esm2015/src/render3/util/discovery_utils.js +146 -119
- package/esm2015/src/render3/util/global_utils.js +5 -5
- package/esm2015/src/render3/util/view_utils.js +6 -6
- package/esm2015/src/render3/view_engine_compatibility.js +16 -17
- package/esm2015/src/render3/view_ref.js +16 -13
- package/esm2015/src/sanitization/bypass.js +1 -1
- package/esm2015/src/sanitization/sanitization.js +20 -5
- package/esm2015/src/util/array_utils.js +240 -1
- package/esm2015/src/util/assert.js +37 -21
- package/esm2015/src/util/char_code.js +8 -0
- package/esm2015/src/util/iterable.js +4 -1
- package/esm2015/src/util/ng_dev_mode.js +1 -12
- package/esm2015/src/util/stringify.js +14 -1
- package/esm2015/src/version.js +1 -1
- package/esm2015/testing/src/r3_test_bed.js +5 -1
- package/esm2015/testing/src/r3_test_bed_compiler.js +2 -12
- package/esm2015/testing/src/styling.js +103 -0
- package/esm5/core.js +17 -17
- package/esm5/src/application_ref.js +6 -6
- package/esm5/src/core_private_export.js +7 -7
- package/esm5/src/core_render3_private_export.js +2 -2
- package/esm5/src/debug/debug_node.js +29 -11
- package/esm5/src/i18n/locale_data_api.js +1 -2
- package/esm5/src/interface/type.js +1 -1
- package/esm5/src/metadata/ng_module.js +1 -1
- package/esm5/src/render/api.js +4 -1
- package/esm5/src/render3/assert.js +4 -1
- package/esm5/src/render3/bindings.js +19 -2
- package/esm5/src/render3/component.js +47 -22
- package/esm5/src/render3/component_ref.js +9 -14
- package/esm5/src/render3/definition.js +3 -1
- package/esm5/src/render3/di.js +3 -4
- package/esm5/src/render3/di_setup.js +4 -5
- package/esm5/src/render3/errors.js +3 -1
- package/esm5/src/render3/features/inherit_definition_feature.js +36 -12
- package/esm5/src/render3/features/ng_onchanges_feature.js +1 -1
- package/esm5/src/render3/global_utils_api.js +3 -3
- package/esm5/src/render3/i18n.js +51 -51
- package/esm5/src/render3/index.js +2 -2
- package/esm5/src/render3/instructions/advance.js +9 -11
- package/esm5/src/render3/instructions/all.js +1 -2
- package/esm5/src/render3/instructions/attribute.js +5 -6
- package/esm5/src/render3/instructions/attribute_interpolation.js +31 -21
- package/esm5/src/render3/instructions/change_detection.js +8 -21
- package/esm5/src/render3/instructions/class_map_interpolation.js +13 -12
- package/esm5/src/render3/instructions/container.js +13 -12
- package/esm5/src/render3/instructions/element.js +36 -108
- package/esm5/src/render3/instructions/element_container.js +8 -9
- package/esm5/src/render3/instructions/embedded_view.js +7 -7
- package/esm5/src/render3/instructions/host_property.js +8 -7
- package/esm5/src/render3/instructions/listener.js +13 -13
- package/esm5/src/render3/instructions/lview_debug.js +56 -15
- package/esm5/src/render3/instructions/projection.js +6 -5
- package/esm5/src/render3/instructions/property.js +17 -6
- package/esm5/src/render3/instructions/property_interpolation.js +31 -23
- package/esm5/src/render3/instructions/shared.js +247 -207
- package/esm5/src/render3/instructions/storage.js +4 -6
- package/esm5/src/render3/instructions/style_prop_interpolation.js +12 -12
- package/esm5/src/render3/instructions/styling.js +685 -367
- package/esm5/src/render3/instructions/text.js +5 -5
- package/esm5/src/render3/interfaces/definition.js +1 -1
- package/esm5/src/render3/interfaces/node.js +49 -1
- package/esm5/src/render3/interfaces/styling.js +57 -1
- package/esm5/src/render3/interfaces/view.js +1 -1
- package/esm5/src/render3/jit/environment.js +1 -3
- package/esm5/src/render3/node_manipulation.js +167 -54
- package/esm5/src/render3/node_selector_matcher.js +40 -20
- package/esm5/src/render3/node_util.js +12 -7
- package/esm5/src/render3/pipe.js +4 -6
- package/esm5/src/render3/query.js +25 -24
- package/esm5/src/render3/state.js +34 -131
- package/esm5/src/render3/styling/class_differ.js +39 -0
- package/esm5/src/render3/styling/static_styling.js +42 -0
- package/esm5/src/render3/styling/style_binding_list.js +411 -0
- package/esm5/src/render3/styling/styling_parser.js +265 -0
- package/esm5/src/render3/tokens.js +2 -2
- package/esm5/src/render3/util/attrs_utils.js +117 -2
- package/esm5/src/render3/util/change_detection_utils.js +23 -0
- package/esm5/src/render3/util/discovery_utils.js +115 -99
- package/esm5/src/render3/util/global_utils.js +5 -5
- package/esm5/src/render3/util/view_utils.js +5 -5
- package/esm5/src/render3/view_engine_compatibility.js +37 -39
- package/esm5/src/render3/view_ref.js +14 -13
- package/esm5/src/sanitization/bypass.js +1 -1
- package/esm5/src/sanitization/sanitization.js +16 -5
- package/esm5/src/util/array_utils.js +240 -1
- package/esm5/src/util/assert.js +37 -21
- package/esm5/src/util/char_code.js +8 -0
- package/esm5/src/util/iterable.js +4 -1
- package/esm5/src/util/ng_dev_mode.js +1 -12
- package/esm5/src/util/stringify.js +14 -1
- package/esm5/src/version.js +1 -1
- package/esm5/testing/src/r3_test_bed.js +9 -1
- package/esm5/testing/src/r3_test_bed_compiler.js +2 -9
- package/esm5/testing/src/styling.js +82 -0
- package/fesm2015/core.js +5917 -6880
- package/fesm2015/core.js.map +1 -1
- package/fesm2015/testing.js +6 -12
- package/fesm2015/testing.js.map +1 -1
- package/fesm5/core.js +3588 -3884
- package/fesm5/core.js.map +1 -1
- package/fesm5/testing.js +10 -9
- package/fesm5/testing.js.map +1 -1
- package/package.json +1 -1
- package/src/r3_symbols.d.ts +1 -1
- package/testing/testing.d.ts +1 -3
- package/testing/testing.metadata.json +1 -1
- package/testing.d.ts +1 -1
- package/esm2015/global.js +0 -7
- package/esm2015/src/render3/instructions/alloc_host_vars.js +0 -80
- package/esm2015/src/render3/styling/bindings.js +0 -1248
- package/esm2015/src/render3/styling/map_based_bindings.js +0 -384
- package/esm2015/src/render3/styling/state.js +0 -135
- package/esm2015/src/render3/styling/styling_debug.js +0 -655
- package/esm2015/src/render3/util/styling_utils.js +0 -625
- package/esm5/global.js +0 -9
- package/esm5/src/render3/instructions/alloc_host_vars.js +0 -62
- package/esm5/src/render3/styling/bindings.js +0 -949
- package/esm5/src/render3/styling/map_based_bindings.js +0 -310
- package/esm5/src/render3/styling/state.js +0 -56
- package/esm5/src/render3/styling/styling_debug.js +0 -315
- package/esm5/src/render3/util/styling_utils.js +0 -378
|
@@ -1,625 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @fileoverview added by tsickle
|
|
3
|
-
* Generated from: packages/core/src/render3/util/styling_utils.ts
|
|
4
|
-
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
|
5
|
-
*/
|
|
6
|
-
/**
|
|
7
|
-
* @license
|
|
8
|
-
* Copyright Google Inc. All Rights Reserved.
|
|
9
|
-
*
|
|
10
|
-
* Use of this source code is governed by an MIT-style license that can be
|
|
11
|
-
* found in the LICENSE file at https://angular.io/license
|
|
12
|
-
*/
|
|
13
|
-
import { unwrapSafeValue } from '../../sanitization/bypass';
|
|
14
|
-
import { NO_CHANGE } from '../tokens';
|
|
15
|
-
/** @type {?} */
|
|
16
|
-
export const MAP_BASED_ENTRY_PROP_NAME = '[MAP]';
|
|
17
|
-
/** @type {?} */
|
|
18
|
-
export const TEMPLATE_DIRECTIVE_INDEX = 0;
|
|
19
|
-
/**
|
|
20
|
-
* Default fallback value for a styling binding.
|
|
21
|
-
*
|
|
22
|
-
* A value of `null` is used here which signals to the styling algorithm that
|
|
23
|
-
* the styling value is not present. This way if there are no other values
|
|
24
|
-
* detected then it will be removed once the style/class property is dirty and
|
|
25
|
-
* diffed within the styling algorithm present in `flushStyling`.
|
|
26
|
-
* @type {?}
|
|
27
|
-
*/
|
|
28
|
-
export const DEFAULT_BINDING_VALUE = null;
|
|
29
|
-
/** @type {?} */
|
|
30
|
-
export const DEFAULT_BINDING_INDEX = 0;
|
|
31
|
-
/** @type {?} */
|
|
32
|
-
const DEFAULT_TOTAL_SOURCES = 1;
|
|
33
|
-
// The first bit value reflects a map-based binding value's bit.
|
|
34
|
-
// The reason why it's always activated for every entry in the map
|
|
35
|
-
// is so that if any map-binding values update then all other prop
|
|
36
|
-
// based bindings will pass the guard check automatically without
|
|
37
|
-
// any extra code or flags.
|
|
38
|
-
/** @type {?} */
|
|
39
|
-
export const DEFAULT_GUARD_MASK_VALUE = 0b1;
|
|
40
|
-
/**
|
|
41
|
-
* Creates a new instance of the `TStylingContext`.
|
|
42
|
-
*
|
|
43
|
-
* The `TStylingContext` is used as a manifest of all style or all class bindings on
|
|
44
|
-
* an element. Because it is a T-level data-structure, it is only created once per
|
|
45
|
-
* tNode for styles and for classes. This function allocates a new instance of a
|
|
46
|
-
* `TStylingContext` with the initial values (see `interfaces.ts` for more info).
|
|
47
|
-
* @param {?} initialStyling
|
|
48
|
-
* @param {?} hasDirectives
|
|
49
|
-
* @return {?}
|
|
50
|
-
*/
|
|
51
|
-
export function allocTStylingContext(initialStyling, hasDirectives) {
|
|
52
|
-
initialStyling = initialStyling || allocStylingMapArray(null);
|
|
53
|
-
return [
|
|
54
|
-
DEFAULT_TOTAL_SOURCES,
|
|
55
|
-
initialStyling,
|
|
56
|
-
];
|
|
57
|
-
}
|
|
58
|
-
/**
|
|
59
|
-
* @param {?} value
|
|
60
|
-
* @return {?}
|
|
61
|
-
*/
|
|
62
|
-
export function allocStylingMapArray(value) {
|
|
63
|
-
return [value];
|
|
64
|
-
}
|
|
65
|
-
/**
|
|
66
|
-
* @param {?} tNode
|
|
67
|
-
* @param {?} flag
|
|
68
|
-
* @return {?}
|
|
69
|
-
*/
|
|
70
|
-
export function hasConfig(tNode, flag) {
|
|
71
|
-
return (tNode.flags & flag) !== 0;
|
|
72
|
-
}
|
|
73
|
-
/**
|
|
74
|
-
* Determines whether or not to apply styles/classes directly or via context resolution.
|
|
75
|
-
*
|
|
76
|
-
* There are three cases that are matched here:
|
|
77
|
-
* 1. there are no directives present AND `ngDevMode` is falsy
|
|
78
|
-
* 2. the `firstUpdatePass` has not already run (which means that
|
|
79
|
-
* there are more bindings to register and, therefore, direct
|
|
80
|
-
* style/class application is not yet possible)
|
|
81
|
-
* 3. There are no collisions (i.e. properties with more than one binding) across multiple
|
|
82
|
-
* sources (i.e. template + directive, directive + directive, directive + component)
|
|
83
|
-
* @param {?} tNode
|
|
84
|
-
* @param {?} isClassBased
|
|
85
|
-
* @param {?} firstUpdatePass
|
|
86
|
-
* @return {?}
|
|
87
|
-
*/
|
|
88
|
-
export function allowDirectStyling(tNode, isClassBased, firstUpdatePass) {
|
|
89
|
-
/** @type {?} */
|
|
90
|
-
let allow = false;
|
|
91
|
-
// if no directives are present then we do not need populate a context at all. This
|
|
92
|
-
// is because duplicate prop bindings cannot be registered through the template. If
|
|
93
|
-
// and when this happens we can safely apply the value directly without context
|
|
94
|
-
// resolution...
|
|
95
|
-
/** @type {?} */
|
|
96
|
-
const hasDirectives = hasConfig(tNode, 128 /* hasHostBindings */);
|
|
97
|
-
if (!hasDirectives) {
|
|
98
|
-
// `ngDevMode` is required to be checked here because tests/debugging rely on the context being
|
|
99
|
-
// populated. If things are in production mode then there is no need to build a context
|
|
100
|
-
// therefore the direct apply can be allowed (even on the first update).
|
|
101
|
-
allow = ngDevMode ? !firstUpdatePass : true;
|
|
102
|
-
}
|
|
103
|
-
else if (!firstUpdatePass) {
|
|
104
|
-
/** @type {?} */
|
|
105
|
-
const duplicateStylingFlag = isClassBased ? 8192 /* hasDuplicateClassBindings */ : 262144 /* hasDuplicateStyleBindings */;
|
|
106
|
-
/** @type {?} */
|
|
107
|
-
const hasDuplicates = hasConfig(tNode, duplicateStylingFlag);
|
|
108
|
-
/** @type {?} */
|
|
109
|
-
const hasOnlyMapOrPropsFlag = isClassBased ? 1536 /* hasClassPropAndMapBindings */ :
|
|
110
|
-
49152 /* hasStylePropAndMapBindings */;
|
|
111
|
-
/** @type {?} */
|
|
112
|
-
const hasOnlyMapsOrOnlyProps = (tNode.flags & hasOnlyMapOrPropsFlag) !== hasOnlyMapOrPropsFlag;
|
|
113
|
-
allow = !hasDuplicates && hasOnlyMapsOrOnlyProps;
|
|
114
|
-
}
|
|
115
|
-
return allow;
|
|
116
|
-
}
|
|
117
|
-
/**
|
|
118
|
-
* @param {?} tNode
|
|
119
|
-
* @param {?} flag
|
|
120
|
-
* @return {?}
|
|
121
|
-
*/
|
|
122
|
-
export function patchConfig(tNode, flag) {
|
|
123
|
-
tNode.flags |= flag;
|
|
124
|
-
}
|
|
125
|
-
/**
|
|
126
|
-
* @param {?} context
|
|
127
|
-
* @param {?} index
|
|
128
|
-
* @return {?}
|
|
129
|
-
*/
|
|
130
|
-
export function getProp(context, index) {
|
|
131
|
-
return (/** @type {?} */ (context[index + 3 /* PropOffset */]));
|
|
132
|
-
}
|
|
133
|
-
/**
|
|
134
|
-
* @param {?} context
|
|
135
|
-
* @param {?} index
|
|
136
|
-
* @return {?}
|
|
137
|
-
*/
|
|
138
|
-
function getPropConfig(context, index) {
|
|
139
|
-
return ((/** @type {?} */ (context[index + 0 /* ConfigOffset */]))) &
|
|
140
|
-
1 /* Mask */;
|
|
141
|
-
}
|
|
142
|
-
/**
|
|
143
|
-
* @param {?} context
|
|
144
|
-
* @param {?} index
|
|
145
|
-
* @return {?}
|
|
146
|
-
*/
|
|
147
|
-
export function isSanitizationRequired(context, index) {
|
|
148
|
-
return (getPropConfig(context, index) & 1 /* SanitizationRequired */) !==
|
|
149
|
-
0;
|
|
150
|
-
}
|
|
151
|
-
/**
|
|
152
|
-
* @param {?} context
|
|
153
|
-
* @param {?} index
|
|
154
|
-
* @param {?} isHostBinding
|
|
155
|
-
* @return {?}
|
|
156
|
-
*/
|
|
157
|
-
export function getGuardMask(context, index, isHostBinding) {
|
|
158
|
-
/** @type {?} */
|
|
159
|
-
const position = index + (isHostBinding ? 2 /* HostBindingsBitGuardOffset */ :
|
|
160
|
-
1 /* TemplateBitGuardOffset */);
|
|
161
|
-
return (/** @type {?} */ (context[position]));
|
|
162
|
-
}
|
|
163
|
-
/**
|
|
164
|
-
* @param {?} context
|
|
165
|
-
* @param {?} index
|
|
166
|
-
* @param {?} maskValue
|
|
167
|
-
* @param {?} isHostBinding
|
|
168
|
-
* @return {?}
|
|
169
|
-
*/
|
|
170
|
-
export function setGuardMask(context, index, maskValue, isHostBinding) {
|
|
171
|
-
/** @type {?} */
|
|
172
|
-
const position = index + (isHostBinding ? 2 /* HostBindingsBitGuardOffset */ :
|
|
173
|
-
1 /* TemplateBitGuardOffset */);
|
|
174
|
-
context[position] = maskValue;
|
|
175
|
-
}
|
|
176
|
-
/**
|
|
177
|
-
* @param {?} context
|
|
178
|
-
* @return {?}
|
|
179
|
-
*/
|
|
180
|
-
export function getValuesCount(context) {
|
|
181
|
-
return getTotalSources(context) + 1;
|
|
182
|
-
}
|
|
183
|
-
/**
|
|
184
|
-
* @param {?} context
|
|
185
|
-
* @return {?}
|
|
186
|
-
*/
|
|
187
|
-
export function getTotalSources(context) {
|
|
188
|
-
return context[0 /* TotalSourcesPosition */];
|
|
189
|
-
}
|
|
190
|
-
/**
|
|
191
|
-
* @param {?} context
|
|
192
|
-
* @param {?} index
|
|
193
|
-
* @param {?} offset
|
|
194
|
-
* @return {?}
|
|
195
|
-
*/
|
|
196
|
-
export function getBindingValue(context, index, offset) {
|
|
197
|
-
return (/** @type {?} */ (context[index + 4 /* BindingsStartOffset */ + offset]));
|
|
198
|
-
}
|
|
199
|
-
/**
|
|
200
|
-
* @param {?} context
|
|
201
|
-
* @param {?} index
|
|
202
|
-
* @return {?}
|
|
203
|
-
*/
|
|
204
|
-
export function getDefaultValue(context, index) {
|
|
205
|
-
return (/** @type {?} */ (context[index + 4 /* BindingsStartOffset */ + getTotalSources(context)]));
|
|
206
|
-
}
|
|
207
|
-
/**
|
|
208
|
-
* @param {?} context
|
|
209
|
-
* @param {?} index
|
|
210
|
-
* @param {?} value
|
|
211
|
-
* @return {?}
|
|
212
|
-
*/
|
|
213
|
-
export function setDefaultValue(context, index, value) {
|
|
214
|
-
return context[index + 4 /* BindingsStartOffset */ + getTotalSources(context)] =
|
|
215
|
-
value;
|
|
216
|
-
}
|
|
217
|
-
/**
|
|
218
|
-
* @param {?} data
|
|
219
|
-
* @param {?} bindingIndex
|
|
220
|
-
* @param {?} value
|
|
221
|
-
* @return {?}
|
|
222
|
-
*/
|
|
223
|
-
export function setValue(data, bindingIndex, value) {
|
|
224
|
-
data[bindingIndex] = value;
|
|
225
|
-
}
|
|
226
|
-
/**
|
|
227
|
-
* @template T
|
|
228
|
-
* @param {?} data
|
|
229
|
-
* @param {?} bindingIndex
|
|
230
|
-
* @return {?}
|
|
231
|
-
*/
|
|
232
|
-
export function getValue(data, bindingIndex) {
|
|
233
|
-
return bindingIndex !== 0 ? (/** @type {?} */ (data[bindingIndex])) : null;
|
|
234
|
-
}
|
|
235
|
-
/**
|
|
236
|
-
* @param {?} context
|
|
237
|
-
* @param {?} tNode
|
|
238
|
-
* @param {?} isClassBased
|
|
239
|
-
* @return {?}
|
|
240
|
-
*/
|
|
241
|
-
export function getPropValuesStartPosition(context, tNode, isClassBased) {
|
|
242
|
-
/** @type {?} */
|
|
243
|
-
let startPosition = 2 /* ValuesStartPosition */;
|
|
244
|
-
/** @type {?} */
|
|
245
|
-
const flag = isClassBased ? 512 /* hasClassMapBindings */ : 16384 /* hasStyleMapBindings */;
|
|
246
|
-
if (hasConfig(tNode, flag)) {
|
|
247
|
-
startPosition += 4 /* BindingsStartOffset */ + getValuesCount(context);
|
|
248
|
-
}
|
|
249
|
-
return startPosition;
|
|
250
|
-
}
|
|
251
|
-
/**
|
|
252
|
-
* @param {?} a
|
|
253
|
-
* @param {?} b
|
|
254
|
-
* @return {?}
|
|
255
|
-
*/
|
|
256
|
-
export function hasValueChangedUnwrapSafeValue(a, b) {
|
|
257
|
-
return hasValueChanged(unwrapSafeValue(a), unwrapSafeValue(b));
|
|
258
|
-
}
|
|
259
|
-
/**
|
|
260
|
-
* @param {?} a
|
|
261
|
-
* @param {?} b
|
|
262
|
-
* @return {?}
|
|
263
|
-
*/
|
|
264
|
-
export function hasValueChanged(a, b) {
|
|
265
|
-
if (b === NO_CHANGE)
|
|
266
|
-
return false;
|
|
267
|
-
/** @type {?} */
|
|
268
|
-
const compareValueA = Array.isArray(a) ? a[0 /* RawValuePosition */] : a;
|
|
269
|
-
/** @type {?} */
|
|
270
|
-
const compareValueB = Array.isArray(b) ? b[0 /* RawValuePosition */] : b;
|
|
271
|
-
return !Object.is(compareValueA, compareValueB);
|
|
272
|
-
}
|
|
273
|
-
/**
|
|
274
|
-
* Determines whether the provided styling value is truthy or falsy.
|
|
275
|
-
* @template T
|
|
276
|
-
* @param {?} value
|
|
277
|
-
* @return {?}
|
|
278
|
-
*/
|
|
279
|
-
export function isStylingValueDefined(value) {
|
|
280
|
-
// the reason why null is compared against is because
|
|
281
|
-
// a CSS class value that is set to `false` must be
|
|
282
|
-
// respected (otherwise it would be treated as falsy).
|
|
283
|
-
// Empty string values are because developers usually
|
|
284
|
-
// set a value to an empty string to remove it.
|
|
285
|
-
return value != null && value !== '';
|
|
286
|
-
}
|
|
287
|
-
/**
|
|
288
|
-
* @param {?} a
|
|
289
|
-
* @param {?} b
|
|
290
|
-
* @param {?=} separator
|
|
291
|
-
* @return {?}
|
|
292
|
-
*/
|
|
293
|
-
export function concatString(a, b, separator = ' ') {
|
|
294
|
-
return a + ((b.length && a.length) ? separator : '') + b;
|
|
295
|
-
}
|
|
296
|
-
/**
|
|
297
|
-
* @param {?} value
|
|
298
|
-
* @return {?}
|
|
299
|
-
*/
|
|
300
|
-
export function hyphenate(value) {
|
|
301
|
-
return value.replace(/[a-z][A-Z]/g, (/**
|
|
302
|
-
* @param {?} v
|
|
303
|
-
* @return {?}
|
|
304
|
-
*/
|
|
305
|
-
v => v.charAt(0) + '-' + v.charAt(1))).toLowerCase();
|
|
306
|
-
}
|
|
307
|
-
/**
|
|
308
|
-
* Returns an instance of `StylingMapArray`.
|
|
309
|
-
*
|
|
310
|
-
* This function is designed to find an instance of `StylingMapArray` in case it is stored
|
|
311
|
-
* inside of an instance of `TStylingContext`. When a styling context is created it
|
|
312
|
-
* will copy over an initial styling values from the tNode (which are stored as a
|
|
313
|
-
* `StylingMapArray` on the `tNode.classes` or `tNode.styles` values).
|
|
314
|
-
* @param {?} value
|
|
315
|
-
* @return {?}
|
|
316
|
-
*/
|
|
317
|
-
export function getStylingMapArray(value) {
|
|
318
|
-
return isStylingContext(value) ?
|
|
319
|
-
((/** @type {?} */ (value)))[1 /* InitialStylingValuePosition */] :
|
|
320
|
-
(/** @type {?} */ (value));
|
|
321
|
-
}
|
|
322
|
-
/**
|
|
323
|
-
* @param {?} value
|
|
324
|
-
* @return {?}
|
|
325
|
-
*/
|
|
326
|
-
export function isStylingContext(value) {
|
|
327
|
-
// the StylingMapArray is in the format of [initial, prop, string, prop, string]
|
|
328
|
-
// and this is the defining value to distinguish between arrays
|
|
329
|
-
return Array.isArray(value) && value.length >= 2 /* ValuesStartPosition */ &&
|
|
330
|
-
typeof value[1] !== 'string';
|
|
331
|
-
}
|
|
332
|
-
/**
|
|
333
|
-
* @param {?} value
|
|
334
|
-
* @return {?}
|
|
335
|
-
*/
|
|
336
|
-
export function isStylingMapArray(value) {
|
|
337
|
-
// the StylingMapArray is in the format of [initial, prop, string, prop, string]
|
|
338
|
-
// and this is the defining value to distinguish between arrays
|
|
339
|
-
return Array.isArray(value) &&
|
|
340
|
-
(typeof ((/** @type {?} */ (value)))[1 /* ValuesStartPosition */] === 'string');
|
|
341
|
-
}
|
|
342
|
-
/**
|
|
343
|
-
* @param {?} context
|
|
344
|
-
* @return {?}
|
|
345
|
-
*/
|
|
346
|
-
export function getInitialStylingValue(context) {
|
|
347
|
-
/** @type {?} */
|
|
348
|
-
const map = getStylingMapArray(context);
|
|
349
|
-
return map && ((/** @type {?} */ (map[0 /* RawValuePosition */]))) || '';
|
|
350
|
-
}
|
|
351
|
-
/**
|
|
352
|
-
* @param {?} tNode
|
|
353
|
-
* @return {?}
|
|
354
|
-
*/
|
|
355
|
-
export function hasClassInput(tNode) {
|
|
356
|
-
return (tNode.flags & 16 /* hasClassInput */) !== 0;
|
|
357
|
-
}
|
|
358
|
-
/**
|
|
359
|
-
* @param {?} tNode
|
|
360
|
-
* @return {?}
|
|
361
|
-
*/
|
|
362
|
-
export function hasStyleInput(tNode) {
|
|
363
|
-
return (tNode.flags & 32 /* hasStyleInput */) !== 0;
|
|
364
|
-
}
|
|
365
|
-
/**
|
|
366
|
-
* @param {?} map
|
|
367
|
-
* @param {?} index
|
|
368
|
-
* @return {?}
|
|
369
|
-
*/
|
|
370
|
-
export function getMapProp(map, index) {
|
|
371
|
-
return (/** @type {?} */ (map[index + 0 /* PropOffset */]));
|
|
372
|
-
}
|
|
373
|
-
/** @type {?} */
|
|
374
|
-
const MAP_DIRTY_VALUE = typeof ngDevMode !== 'undefined' && ngDevMode ? {} : { MAP_DIRTY_VALUE: true };
|
|
375
|
-
/**
|
|
376
|
-
* @param {?} map
|
|
377
|
-
* @return {?}
|
|
378
|
-
*/
|
|
379
|
-
export function setMapAsDirty(map) {
|
|
380
|
-
map[0 /* RawValuePosition */] = MAP_DIRTY_VALUE;
|
|
381
|
-
}
|
|
382
|
-
/**
|
|
383
|
-
* @param {?} map
|
|
384
|
-
* @param {?} index
|
|
385
|
-
* @param {?} value
|
|
386
|
-
* @return {?}
|
|
387
|
-
*/
|
|
388
|
-
export function setMapValue(map, index, value) {
|
|
389
|
-
map[index + 1 /* ValueOffset */] = value;
|
|
390
|
-
}
|
|
391
|
-
/**
|
|
392
|
-
* @param {?} map
|
|
393
|
-
* @param {?} index
|
|
394
|
-
* @return {?}
|
|
395
|
-
*/
|
|
396
|
-
export function getMapValue(map, index) {
|
|
397
|
-
return (/** @type {?} */ (map[index + 1 /* ValueOffset */]));
|
|
398
|
-
}
|
|
399
|
-
/**
|
|
400
|
-
* @param {?} classes
|
|
401
|
-
* @return {?}
|
|
402
|
-
*/
|
|
403
|
-
export function forceClassesAsString(classes) {
|
|
404
|
-
if (classes && typeof classes !== 'string') {
|
|
405
|
-
classes = Object.keys(classes).join(' ');
|
|
406
|
-
}
|
|
407
|
-
return ((/** @type {?} */ (classes))) || '';
|
|
408
|
-
}
|
|
409
|
-
/**
|
|
410
|
-
* @param {?} styles
|
|
411
|
-
* @param {?} hyphenateProps
|
|
412
|
-
* @return {?}
|
|
413
|
-
*/
|
|
414
|
-
export function forceStylesAsString(styles, hyphenateProps) {
|
|
415
|
-
if (typeof styles == 'string')
|
|
416
|
-
return styles;
|
|
417
|
-
/** @type {?} */
|
|
418
|
-
let str = '';
|
|
419
|
-
if (styles) {
|
|
420
|
-
/** @type {?} */
|
|
421
|
-
const props = Object.keys(styles);
|
|
422
|
-
for (let i = 0; i < props.length; i++) {
|
|
423
|
-
/** @type {?} */
|
|
424
|
-
const prop = props[i];
|
|
425
|
-
/** @type {?} */
|
|
426
|
-
const propLabel = hyphenateProps ? hyphenate(prop) : prop;
|
|
427
|
-
/** @type {?} */
|
|
428
|
-
const value = styles[prop];
|
|
429
|
-
if (value !== null) {
|
|
430
|
-
str = concatString(str, `${propLabel}:${value}`, ';');
|
|
431
|
-
}
|
|
432
|
-
}
|
|
433
|
-
}
|
|
434
|
-
return str;
|
|
435
|
-
}
|
|
436
|
-
/**
|
|
437
|
-
* @param {?} directiveOrSourceId
|
|
438
|
-
* @return {?}
|
|
439
|
-
*/
|
|
440
|
-
export function isHostStylingActive(directiveOrSourceId) {
|
|
441
|
-
return directiveOrSourceId !== TEMPLATE_DIRECTIVE_INDEX;
|
|
442
|
-
}
|
|
443
|
-
/**
|
|
444
|
-
* Converts the provided styling map array into a string.
|
|
445
|
-
*
|
|
446
|
-
* Classes => `one two three`
|
|
447
|
-
* Styles => `prop:value; prop2:value2`
|
|
448
|
-
* @param {?} map
|
|
449
|
-
* @param {?} isClassBased
|
|
450
|
-
* @return {?}
|
|
451
|
-
*/
|
|
452
|
-
export function stylingMapToString(map, isClassBased) {
|
|
453
|
-
/** @type {?} */
|
|
454
|
-
let str = '';
|
|
455
|
-
for (let i = 1 /* ValuesStartPosition */; i < map.length; i += 2 /* TupleSize */) {
|
|
456
|
-
/** @type {?} */
|
|
457
|
-
const prop = getMapProp(map, i);
|
|
458
|
-
/** @type {?} */
|
|
459
|
-
const value = (/** @type {?} */ (getMapValue(map, i)));
|
|
460
|
-
/** @type {?} */
|
|
461
|
-
const attrValue = concatString(prop, isClassBased ? '' : value, ':');
|
|
462
|
-
str = concatString(str, attrValue, isClassBased ? ' ' : '; ');
|
|
463
|
-
}
|
|
464
|
-
return str;
|
|
465
|
-
}
|
|
466
|
-
/**
|
|
467
|
-
* Converts the provided styling map array into a key value map.
|
|
468
|
-
* @param {?} map
|
|
469
|
-
* @return {?}
|
|
470
|
-
*/
|
|
471
|
-
export function stylingMapToStringMap(map) {
|
|
472
|
-
/** @type {?} */
|
|
473
|
-
let stringMap = {};
|
|
474
|
-
if (map) {
|
|
475
|
-
for (let i = 1 /* ValuesStartPosition */; i < map.length; i += 2 /* TupleSize */) {
|
|
476
|
-
/** @type {?} */
|
|
477
|
-
const prop = getMapProp(map, i);
|
|
478
|
-
/** @type {?} */
|
|
479
|
-
const value = (/** @type {?} */ (getMapValue(map, i)));
|
|
480
|
-
stringMap[prop] = value;
|
|
481
|
-
}
|
|
482
|
-
}
|
|
483
|
-
return stringMap;
|
|
484
|
-
}
|
|
485
|
-
/**
|
|
486
|
-
* Inserts the provided item into the provided styling array at the right spot.
|
|
487
|
-
*
|
|
488
|
-
* The `StylingMapArray` type is a sorted key/value array of entries. This means
|
|
489
|
-
* that when a new entry is inserted it must be placed at the right spot in the
|
|
490
|
-
* array. This function figures out exactly where to place it.
|
|
491
|
-
* @param {?} stylingMapArr
|
|
492
|
-
* @param {?} prop
|
|
493
|
-
* @param {?} value
|
|
494
|
-
* @param {?=} allowOverwrite
|
|
495
|
-
* @return {?}
|
|
496
|
-
*/
|
|
497
|
-
export function addItemToStylingMap(stylingMapArr, prop, value, allowOverwrite) {
|
|
498
|
-
for (let j = 1 /* ValuesStartPosition */; j < stylingMapArr.length; j += 2 /* TupleSize */) {
|
|
499
|
-
/** @type {?} */
|
|
500
|
-
const propAtIndex = getMapProp(stylingMapArr, j);
|
|
501
|
-
if (prop <= propAtIndex) {
|
|
502
|
-
/** @type {?} */
|
|
503
|
-
let applied = false;
|
|
504
|
-
if (propAtIndex === prop) {
|
|
505
|
-
/** @type {?} */
|
|
506
|
-
const valueAtIndex = stylingMapArr[j];
|
|
507
|
-
if (allowOverwrite || !isStylingValueDefined(valueAtIndex)) {
|
|
508
|
-
applied = true;
|
|
509
|
-
setMapValue(stylingMapArr, j, value);
|
|
510
|
-
}
|
|
511
|
-
}
|
|
512
|
-
else {
|
|
513
|
-
applied = true;
|
|
514
|
-
stylingMapArr.splice(j, 0, prop, value);
|
|
515
|
-
}
|
|
516
|
-
return applied;
|
|
517
|
-
}
|
|
518
|
-
}
|
|
519
|
-
stylingMapArr.push(prop, value);
|
|
520
|
-
return true;
|
|
521
|
-
}
|
|
522
|
-
/**
|
|
523
|
-
* Used to convert a {key:value} map into a `StylingMapArray` array.
|
|
524
|
-
*
|
|
525
|
-
* This function will either generate a new `StylingMapArray` instance
|
|
526
|
-
* or it will patch the provided `newValues` map value into an
|
|
527
|
-
* existing `StylingMapArray` value (this only happens if `bindingValue`
|
|
528
|
-
* is an instance of `StylingMapArray`).
|
|
529
|
-
*
|
|
530
|
-
* If a new key/value map is provided with an old `StylingMapArray`
|
|
531
|
-
* value then all properties will be overwritten with their new
|
|
532
|
-
* values or with `null`. This means that the array will never
|
|
533
|
-
* shrink in size (but it will also not be created and thrown
|
|
534
|
-
* away whenever the `{key:value}` map entries change).
|
|
535
|
-
* @param {?} bindingValue
|
|
536
|
-
* @param {?} newValues
|
|
537
|
-
* @param {?=} normalizeProps
|
|
538
|
-
* @return {?}
|
|
539
|
-
*/
|
|
540
|
-
export function normalizeIntoStylingMap(bindingValue, newValues, normalizeProps) {
|
|
541
|
-
/** @type {?} */
|
|
542
|
-
const stylingMapArr = Array.isArray(bindingValue) ? bindingValue : allocStylingMapArray(null);
|
|
543
|
-
stylingMapArr[0 /* RawValuePosition */] = newValues;
|
|
544
|
-
// because the new values may not include all the properties
|
|
545
|
-
// that the old ones had, all values are set to `null` before
|
|
546
|
-
// the new values are applied. This way, when flushed, the
|
|
547
|
-
// styling algorithm knows exactly what style/class values
|
|
548
|
-
// to remove from the element (since they are `null`).
|
|
549
|
-
for (let j = 1 /* ValuesStartPosition */; j < stylingMapArr.length; j += 2 /* TupleSize */) {
|
|
550
|
-
setMapValue(stylingMapArr, j, null);
|
|
551
|
-
}
|
|
552
|
-
/** @type {?} */
|
|
553
|
-
let props = null;
|
|
554
|
-
/** @type {?} */
|
|
555
|
-
let map;
|
|
556
|
-
/** @type {?} */
|
|
557
|
-
let allValuesTrue = false;
|
|
558
|
-
if (typeof newValues === 'string') { // [class] bindings allow string values
|
|
559
|
-
props = splitOnWhitespace(newValues);
|
|
560
|
-
allValuesTrue = props !== null;
|
|
561
|
-
}
|
|
562
|
-
else {
|
|
563
|
-
props = newValues ? Object.keys(newValues) : null;
|
|
564
|
-
map = newValues;
|
|
565
|
-
}
|
|
566
|
-
if (props) {
|
|
567
|
-
for (let i = 0; i < props.length; i++) {
|
|
568
|
-
/** @type {?} */
|
|
569
|
-
const prop = props[i];
|
|
570
|
-
/** @type {?} */
|
|
571
|
-
const newProp = normalizeProps ? hyphenate(prop) : prop;
|
|
572
|
-
/** @type {?} */
|
|
573
|
-
const value = allValuesTrue ? true : (/** @type {?} */ (map))[prop];
|
|
574
|
-
addItemToStylingMap(stylingMapArr, newProp, value, true);
|
|
575
|
-
}
|
|
576
|
-
}
|
|
577
|
-
return stylingMapArr;
|
|
578
|
-
}
|
|
579
|
-
/**
|
|
580
|
-
* @param {?} text
|
|
581
|
-
* @return {?}
|
|
582
|
-
*/
|
|
583
|
-
export function splitOnWhitespace(text) {
|
|
584
|
-
/** @type {?} */
|
|
585
|
-
let array = null;
|
|
586
|
-
/** @type {?} */
|
|
587
|
-
let length = text.length;
|
|
588
|
-
/** @type {?} */
|
|
589
|
-
let start = 0;
|
|
590
|
-
/** @type {?} */
|
|
591
|
-
let foundChar = false;
|
|
592
|
-
for (let i = 0; i < length; i++) {
|
|
593
|
-
/** @type {?} */
|
|
594
|
-
const char = text.charCodeAt(i);
|
|
595
|
-
if (char <= 32 /*' '*/) {
|
|
596
|
-
if (foundChar) {
|
|
597
|
-
if (array === null)
|
|
598
|
-
array = [];
|
|
599
|
-
array.push(text.substring(start, i));
|
|
600
|
-
foundChar = false;
|
|
601
|
-
}
|
|
602
|
-
start = i + 1;
|
|
603
|
-
}
|
|
604
|
-
else {
|
|
605
|
-
foundChar = true;
|
|
606
|
-
}
|
|
607
|
-
}
|
|
608
|
-
if (foundChar) {
|
|
609
|
-
if (array === null)
|
|
610
|
-
array = [];
|
|
611
|
-
array.push(text.substring(start, length));
|
|
612
|
-
foundChar = false;
|
|
613
|
-
}
|
|
614
|
-
return array;
|
|
615
|
-
}
|
|
616
|
-
// TODO (matsko|AndrewKushnir): refactor this once we figure out how to generate separate
|
|
617
|
-
// `input('class') + classMap()` instructions.
|
|
618
|
-
/**
|
|
619
|
-
* @param {?} inputs
|
|
620
|
-
* @return {?}
|
|
621
|
-
*/
|
|
622
|
-
export function selectClassBasedInputName(inputs) {
|
|
623
|
-
return inputs.hasOwnProperty('class') ? 'class' : 'className';
|
|
624
|
-
}
|
|
625
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"styling_utils.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/util/styling_utils.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n* @license\n* Copyright Google Inc. All Rights Reserved.\n*\n* Use of this source code is governed by an MIT-style license that can be\n* found in the LICENSE file at https://angular.io/license\n*/\nimport {unwrapSafeValue} from '../../sanitization/bypass';\nimport {PropertyAliases, TNodeFlags} from '../interfaces/node';\nimport {LStylingData, StylingMapArray, StylingMapArrayIndex, TStylingContext, TStylingContextIndex, TStylingContextPropConfigFlags, TStylingNode} from '../interfaces/styling';\nimport {NO_CHANGE} from '../tokens';\n\nexport const MAP_BASED_ENTRY_PROP_NAME = '[MAP]';\nexport const TEMPLATE_DIRECTIVE_INDEX = 0;\n\n/**\n * Default fallback value for a styling binding.\n *\n * A value of `null` is used here which signals to the styling algorithm that\n * the styling value is not present. This way if there are no other values\n * detected then it will be removed once the style/class property is dirty and\n * diffed within the styling algorithm present in `flushStyling`.\n */\nexport const DEFAULT_BINDING_VALUE = null;\n\nexport const DEFAULT_BINDING_INDEX = 0;\n\nconst DEFAULT_TOTAL_SOURCES = 1;\n\n// The first bit value reflects a map-based binding value's bit.\n// The reason why it's always activated for every entry in the map\n// is so that if any map-binding values update then all other prop\n// based bindings will pass the guard check automatically without\n// any extra code or flags.\nexport const DEFAULT_GUARD_MASK_VALUE = 0b1;\n\n/**\n * Creates a new instance of the `TStylingContext`.\n *\n * The `TStylingContext` is used as a manifest of all style or all class bindings on\n * an element. Because it is a T-level data-structure, it is only created once per\n * tNode for styles and for classes. This function allocates a new instance of a\n * `TStylingContext` with the initial values (see `interfaces.ts` for more info).\n */\nexport function allocTStylingContext(\n    initialStyling: StylingMapArray | null, hasDirectives: boolean): TStylingContext {\n  initialStyling = initialStyling || allocStylingMapArray(null);\n  return [\n    DEFAULT_TOTAL_SOURCES,  // 1) total amount of styling sources (template, directives, etc...)\n    initialStyling,         // 2) initial styling values\n  ];\n}\n\nexport function allocStylingMapArray(value: {} | string | null): StylingMapArray {\n  return [value];\n}\n\nexport function hasConfig(tNode: TStylingNode, flag: TNodeFlags) {\n  return (tNode.flags & flag) !== 0;\n}\n\n/**\n * Determines whether or not to apply styles/classes directly or via context resolution.\n *\n * There are three cases that are matched here:\n * 1. there are no directives present AND `ngDevMode` is falsy\n * 2. the `firstUpdatePass` has not already run (which means that\n *    there are more bindings to register and, therefore, direct\n *    style/class application is not yet possible)\n * 3. There are no collisions (i.e. properties with more than one binding) across multiple\n *    sources (i.e. template + directive, directive + directive, directive + component)\n */\nexport function allowDirectStyling(\n    tNode: TStylingNode, isClassBased: boolean, firstUpdatePass: boolean): boolean {\n  let allow = false;\n\n  // if no directives are present then we do not need populate a context at all. This\n  // is because duplicate prop bindings cannot be registered through the template. If\n  // and when this happens we can safely apply the value directly without context\n  // resolution...\n  const hasDirectives = hasConfig(tNode, TNodeFlags.hasHostBindings);\n  if (!hasDirectives) {\n    // `ngDevMode` is required to be checked here because tests/debugging rely on the context being\n    // populated. If things are in production mode then there is no need to build a context\n    // therefore the direct apply can be allowed (even on the first update).\n    allow = ngDevMode ? !firstUpdatePass : true;\n  } else if (!firstUpdatePass) {\n    const duplicateStylingFlag =\n        isClassBased ? TNodeFlags.hasDuplicateClassBindings : TNodeFlags.hasDuplicateStyleBindings;\n    const hasDuplicates = hasConfig(tNode, duplicateStylingFlag);\n    const hasOnlyMapOrPropsFlag = isClassBased ? TNodeFlags.hasClassPropAndMapBindings :\n                                                 TNodeFlags.hasStylePropAndMapBindings;\n    const hasOnlyMapsOrOnlyProps = (tNode.flags & hasOnlyMapOrPropsFlag) !== hasOnlyMapOrPropsFlag;\n    allow = !hasDuplicates && hasOnlyMapsOrOnlyProps;\n  }\n\n  return allow;\n}\n\nexport function patchConfig(tNode: TStylingNode, flag: TNodeFlags): void {\n  tNode.flags |= flag;\n}\n\nexport function getProp(context: TStylingContext, index: number): string {\n  return context[index + TStylingContextIndex.PropOffset] as string;\n}\n\nfunction getPropConfig(context: TStylingContext, index: number): number {\n  return (context[index + TStylingContextIndex.ConfigOffset] as number) &\n      TStylingContextPropConfigFlags.Mask;\n}\n\nexport function isSanitizationRequired(context: TStylingContext, index: number): boolean {\n  return (getPropConfig(context, index) & TStylingContextPropConfigFlags.SanitizationRequired) !==\n      0;\n}\n\nexport function getGuardMask(\n    context: TStylingContext, index: number, isHostBinding: boolean): number {\n  const position = index + (isHostBinding ? TStylingContextIndex.HostBindingsBitGuardOffset :\n                                            TStylingContextIndex.TemplateBitGuardOffset);\n  return context[position] as number;\n}\n\nexport function setGuardMask(\n    context: TStylingContext, index: number, maskValue: number, isHostBinding: boolean) {\n  const position = index + (isHostBinding ? TStylingContextIndex.HostBindingsBitGuardOffset :\n                                            TStylingContextIndex.TemplateBitGuardOffset);\n  context[position] = maskValue;\n}\n\nexport function getValuesCount(context: TStylingContext): number {\n  return getTotalSources(context) + 1;\n}\n\nexport function getTotalSources(context: TStylingContext): number {\n  return context[TStylingContextIndex.TotalSourcesPosition];\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  return context[index + TStylingContextIndex.BindingsStartOffset + getTotalSources(context)] as\n             string |\n      boolean | null;\n}\n\nexport function setDefaultValue(\n    context: TStylingContext, index: number, value: string | boolean | null) {\n  return context[index + TStylingContextIndex.BindingsStartOffset + getTotalSources(context)] =\n             value;\n}\n\nexport function setValue(data: LStylingData, bindingIndex: number, value: any) {\n  data[bindingIndex] = value;\n}\n\nexport function getValue<T = any>(data: LStylingData, bindingIndex: number): T|null {\n  return bindingIndex !== 0 ? data[bindingIndex] as T : null;\n}\n\nexport function getPropValuesStartPosition(\n    context: TStylingContext, tNode: TStylingNode, isClassBased: boolean) {\n  let startPosition = TStylingContextIndex.ValuesStartPosition;\n  const flag = isClassBased ? TNodeFlags.hasClassMapBindings : TNodeFlags.hasStyleMapBindings;\n  if (hasConfig(tNode, flag)) {\n    startPosition += TStylingContextIndex.BindingsStartOffset + getValuesCount(context);\n  }\n  return startPosition;\n}\n\nexport function hasValueChangedUnwrapSafeValue(\n    a: NO_CHANGE | StylingMapArray | number | String | string | null | boolean | undefined | {},\n    b: NO_CHANGE | StylingMapArray | number | String | string | null | boolean | undefined |\n        {}): boolean {\n  return hasValueChanged(unwrapSafeValue(a), unwrapSafeValue(b));\n}\n\n\nexport function hasValueChanged(\n    a: NO_CHANGE | StylingMapArray | number | string | null | boolean | undefined | {},\n    b: NO_CHANGE | StylingMapArray | number | string | null | boolean | undefined | {}): boolean {\n  if (b === NO_CHANGE) return false;\n\n  const compareValueA = Array.isArray(a) ? a[StylingMapArrayIndex.RawValuePosition] : a;\n  const compareValueB = Array.isArray(b) ? b[StylingMapArrayIndex.RawValuePosition] : b;\n  return !Object.is(compareValueA, compareValueB);\n}\n\n/**\n * Determines whether the provided styling value is truthy or falsy.\n */\nexport function isStylingValueDefined<T extends string|number|{}|null|undefined>(value: T):\n    value is NonNullable<T> {\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\nexport function concatString(a: string, b: string, separator = ' '): string {\n  return a + ((b.length && a.length) ? separator : '') + b;\n}\n\nexport function hyphenate(value: string): string {\n  return value.replace(/[a-z][A-Z]/g, v => v.charAt(0) + '-' + v.charAt(1)).toLowerCase();\n}\n\n/**\n * Returns an instance of `StylingMapArray`.\n *\n * This function is designed to find an instance of `StylingMapArray` in case it is stored\n * inside of an instance of `TStylingContext`. When a styling context is created it\n * will copy over an initial styling values from the tNode (which are stored as a\n * `StylingMapArray` on the `tNode.classes` or `tNode.styles` values).\n */\nexport function getStylingMapArray(value: TStylingContext | StylingMapArray | null):\n    StylingMapArray|null {\n  return isStylingContext(value) ?\n      (value as TStylingContext)[TStylingContextIndex.InitialStylingValuePosition] :\n      value as StylingMapArray;\n}\n\nexport function isStylingContext(value: any): boolean {\n  // the StylingMapArray is in the format of [initial, prop, string, prop, string]\n  // and this is the defining value to distinguish between arrays\n  return Array.isArray(value) && value.length >= TStylingContextIndex.ValuesStartPosition &&\n      typeof value[1] !== 'string';\n}\n\nexport function isStylingMapArray(value: any): boolean {\n  // the StylingMapArray is in the format of [initial, prop, string, prop, string]\n  // and this is the defining value to distinguish between arrays\n  return Array.isArray(value) &&\n      (typeof(value as StylingMapArray)[StylingMapArrayIndex.ValuesStartPosition] === 'string');\n}\n\nexport function getInitialStylingValue(context: TStylingContext | StylingMapArray | null): string {\n  const map = getStylingMapArray(context);\n  return map && (map[StylingMapArrayIndex.RawValuePosition] as string | null) || '';\n}\n\nexport function hasClassInput(tNode: TStylingNode) {\n  return (tNode.flags & TNodeFlags.hasClassInput) !== 0;\n}\n\nexport function hasStyleInput(tNode: TStylingNode) {\n  return (tNode.flags & TNodeFlags.hasStyleInput) !== 0;\n}\n\nexport function getMapProp(map: StylingMapArray, index: number): string {\n  return map[index + StylingMapArrayIndex.PropOffset] as string;\n}\n\nconst MAP_DIRTY_VALUE =\n    typeof ngDevMode !== 'undefined' && ngDevMode ? {} : {MAP_DIRTY_VALUE: true};\n\nexport function setMapAsDirty(map: StylingMapArray): void {\n  map[StylingMapArrayIndex.RawValuePosition] = MAP_DIRTY_VALUE;\n}\n\nexport function setMapValue(\n    map: StylingMapArray, index: number, value: string | boolean | null): void {\n  map[index + StylingMapArrayIndex.ValueOffset] = value;\n}\n\nexport function getMapValue(map: StylingMapArray, index: number): string|null {\n  return map[index + StylingMapArrayIndex.ValueOffset] as string | null;\n}\n\nexport function forceClassesAsString(classes: string | {[key: string]: any} | null | undefined):\n    string {\n  if (classes && typeof classes !== 'string') {\n    classes = Object.keys(classes).join(' ');\n  }\n  return (classes as string) || '';\n}\n\nexport function forceStylesAsString(\n    styles: {[key: string]: any} | string | null | undefined, hyphenateProps: boolean): string {\n  if (typeof styles == 'string') return styles;\n  let str = '';\n  if (styles) {\n    const props = Object.keys(styles);\n    for (let i = 0; i < props.length; i++) {\n      const prop = props[i];\n      const propLabel = hyphenateProps ? hyphenate(prop) : prop;\n      const value = styles[prop];\n      if (value !== null) {\n        str = concatString(str, `${propLabel}:${value}`, ';');\n      }\n    }\n  }\n  return str;\n}\n\nexport function isHostStylingActive(directiveOrSourceId: number): boolean {\n  return directiveOrSourceId !== TEMPLATE_DIRECTIVE_INDEX;\n}\n\n/**\n * Converts the provided styling map array into a string.\n *\n * Classes => `one two three`\n * Styles => `prop:value; prop2:value2`\n */\nexport function stylingMapToString(map: StylingMapArray, isClassBased: boolean): string {\n  let str = '';\n  for (let i = StylingMapArrayIndex.ValuesStartPosition; i < map.length;\n       i += StylingMapArrayIndex.TupleSize) {\n    const prop = getMapProp(map, i);\n    const value = getMapValue(map, i) as string;\n    const attrValue = concatString(prop, isClassBased ? '' : value, ':');\n    str = concatString(str, attrValue, isClassBased ? ' ' : '; ');\n  }\n  return str;\n}\n\n/**\n * Converts the provided styling map array into a key value map.\n */\nexport function stylingMapToStringMap(map: StylingMapArray | null): {[key: string]: any} {\n  let stringMap: {[key: string]: any} = {};\n  if (map) {\n    for (let i = StylingMapArrayIndex.ValuesStartPosition; i < map.length;\n         i += StylingMapArrayIndex.TupleSize) {\n      const prop = getMapProp(map, i);\n      const value = getMapValue(map, i) as string;\n      stringMap[prop] = value;\n    }\n  }\n  return stringMap;\n}\n\n/**\n * Inserts the provided item into the provided styling array at the right spot.\n *\n * The `StylingMapArray` type is a sorted key/value array of entries. This means\n * that when a new entry is inserted it must be placed at the right spot in the\n * array. This function figures out exactly where to place it.\n */\nexport function addItemToStylingMap(\n    stylingMapArr: StylingMapArray, prop: string, value: string | boolean | null,\n    allowOverwrite?: boolean) {\n  for (let j = StylingMapArrayIndex.ValuesStartPosition; j < stylingMapArr.length;\n       j += StylingMapArrayIndex.TupleSize) {\n    const propAtIndex = getMapProp(stylingMapArr, j);\n    if (prop <= propAtIndex) {\n      let applied = false;\n      if (propAtIndex === prop) {\n        const valueAtIndex = stylingMapArr[j];\n        if (allowOverwrite || !isStylingValueDefined(valueAtIndex)) {\n          applied = true;\n          setMapValue(stylingMapArr, j, value);\n        }\n      } else {\n        applied = true;\n        stylingMapArr.splice(j, 0, prop, value);\n      }\n      return applied;\n    }\n  }\n\n  stylingMapArr.push(prop, value);\n  return true;\n}\n\n/**\n * Used to convert a {key:value} map into a `StylingMapArray` array.\n *\n * This function will either generate a new `StylingMapArray` instance\n * or it will patch the provided `newValues` map value into an\n * existing `StylingMapArray` value (this only happens if `bindingValue`\n * is an instance of `StylingMapArray`).\n *\n * If a new key/value map is provided with an old `StylingMapArray`\n * value then all properties will be overwritten with their new\n * values or with `null`. This means that the array will never\n * shrink in size (but it will also not be created and thrown\n * away whenever the `{key:value}` map entries change).\n */\nexport function normalizeIntoStylingMap(\n    bindingValue: null | StylingMapArray,\n    newValues: {[key: string]: any} | string | null | undefined,\n    normalizeProps?: boolean): StylingMapArray {\n  const stylingMapArr: StylingMapArray =\n      Array.isArray(bindingValue) ? bindingValue : allocStylingMapArray(null);\n  stylingMapArr[StylingMapArrayIndex.RawValuePosition] = newValues;\n\n  // because the new values may not include all the properties\n  // that the old ones had, all values are set to `null` before\n  // the new values are applied. This way, when flushed, the\n  // styling algorithm knows exactly what style/class values\n  // to remove from the element (since they are `null`).\n  for (let j = StylingMapArrayIndex.ValuesStartPosition; j < stylingMapArr.length;\n       j += StylingMapArrayIndex.TupleSize) {\n    setMapValue(stylingMapArr, j, null);\n  }\n\n  let props: string[]|null = null;\n  let map: {[key: string]: any}|undefined|null;\n  let allValuesTrue = false;\n  if (typeof newValues === 'string') {  // [class] bindings allow string values\n    props = splitOnWhitespace(newValues);\n    allValuesTrue = props !== null;\n  } else {\n    props = newValues ? Object.keys(newValues) : null;\n    map = newValues;\n  }\n\n  if (props) {\n    for (let i = 0; i < props.length; i++) {\n      const prop = props[i];\n      const newProp = normalizeProps ? hyphenate(prop) : prop;\n      const value = allValuesTrue ? true : map ![prop];\n      addItemToStylingMap(stylingMapArr, newProp, value, true);\n    }\n  }\n\n  return stylingMapArr;\n}\n\nexport function splitOnWhitespace(text: string): string[]|null {\n  let array: string[]|null = null;\n  let length = text.length;\n  let start = 0;\n  let foundChar = false;\n  for (let i = 0; i < length; i++) {\n    const char = text.charCodeAt(i);\n    if (char <= 32 /*' '*/) {\n      if (foundChar) {\n        if (array === null) array = [];\n        array.push(text.substring(start, i));\n        foundChar = false;\n      }\n      start = i + 1;\n    } else {\n      foundChar = true;\n    }\n  }\n  if (foundChar) {\n    if (array === null) array = [];\n    array.push(text.substring(start, length));\n    foundChar = false;\n  }\n  return array;\n}\n\n// TODO (matsko|AndrewKushnir): refactor this once we figure out how to generate separate\n// `input('class') + classMap()` instructions.\nexport function selectClassBasedInputName(inputs: PropertyAliases): string {\n  return inputs.hasOwnProperty('class') ? 'class' : 'className';\n}\n"]}
|