@angular/core 8.0.3 → 8.1.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- 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 +11379 -9387
- package/bundles/core.umd.js.map +1 -1
- package/bundles/core.umd.min.js +205 -135
- package/bundles/core.umd.min.js.map +1 -1
- package/core.d.ts +1286 -406
- 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/injectable.js +1 -1
- 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/interface/provider.js +1 -1
- 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/directives.js +2 -2
- 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/component_ref.js +4 -2
- 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 +10 -5
- 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 +18 -57
- 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/projection.js +1 -1
- 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 +40 -14
- 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 +92 -80
- 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/esm2015/testing/src/test_bed_common.js +2 -5
- 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/injectable.js +1 -1
- 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/interface/provider.js +1 -1
- 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/directives.js +2 -2
- 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/component_ref.js +4 -2
- 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 +19 -54
- 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/projection.js +1 -1
- 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 +36 -14
- 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 +80 -66
- 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/esm5/testing/src/test_bed_common.js +1 -1
- package/fesm2015/core.js +13604 -10868
- package/fesm2015/core.js.map +1 -1
- package/fesm2015/testing.js +43 -11
- package/fesm2015/testing.js.map +1 -1
- package/fesm5/core.js +11279 -9305
- 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/injectable-pipe/index.js +2 -5
- package/schematics/migrations/move-document/index.js +2 -5
- package/schematics/migrations/static-queries/index.js +2 -5
- package/schematics/migrations/template-var-assignment/index.js +2 -5
- package/src/r3_symbols.d.ts +24 -18
- package/testing/testing.d.ts +2 -5
- package/testing.d.ts +1 -1
|
@@ -1,12 +1,15 @@
|
|
|
1
1
|
import { assertEqual } from '../../util/assert';
|
|
2
2
|
import { FLAGS, HEADER_OFFSET, RENDERER } from '../interfaces/view';
|
|
3
3
|
import { getActiveDirectiveId, getActiveDirectiveSuperClassDepth, getLView, getPreviousOrParentTNode, getSelectedIndex } from '../state';
|
|
4
|
-
import { getInitialClassNameValue, renderStyling, updateClassProp as
|
|
4
|
+
import { getInitialClassNameValue, renderStyling, updateClassMap, updateClassProp as updateclassProp, updateContextWithBindings, updateStyleMap, updateStyleProp as updatestyleProp } from '../styling/class_and_style_bindings';
|
|
5
5
|
import { enqueueHostInstruction, registerHostDirective } from '../styling/host_instructions_queue';
|
|
6
6
|
import { BoundPlayerFactory } from '../styling/player_factory';
|
|
7
7
|
import { DEFAULT_TEMPLATE_DIRECTIVE_INDEX } from '../styling/shared';
|
|
8
8
|
import { getCachedStylingContext, setCachedStylingContext } from '../styling/state';
|
|
9
9
|
import { allocateOrUpdateDirectiveIntoContext, createEmptyStylingContext, forceClassesAsString, forceStylesAsString, getStylingContextFromLView, hasClassInput, hasStyleInput } from '../styling/util';
|
|
10
|
+
import { classMap as newClassMap, classProp as newClassProp, styleMap as newStyleMap, styleProp as newStyleProp, stylingApply as newStylingApply, stylingInit as newStylingInit } from '../styling_next/instructions';
|
|
11
|
+
import { runtimeAllowOldStyling, runtimeIsNewStylingInUse } from '../styling_next/state';
|
|
12
|
+
import { getBindingNameFromIndex } from '../styling_next/util';
|
|
10
13
|
import { NO_CHANGE } from '../tokens';
|
|
11
14
|
import { renderStringify } from '../util/misc_utils';
|
|
12
15
|
import { getRootContext } from '../util/view_traversal_utils';
|
|
@@ -19,18 +22,12 @@ import { scheduleTick, setInputsForProperty } from './shared';
|
|
|
19
22
|
* The instructions present in this file are:
|
|
20
23
|
*
|
|
21
24
|
* Template level styling instructions:
|
|
22
|
-
* -
|
|
23
|
-
* -
|
|
24
|
-
* -
|
|
25
|
-
* -
|
|
26
|
-
* -
|
|
27
|
-
*
|
|
28
|
-
* Host bindings level styling instructions:
|
|
29
|
-
* - elementHostStyling
|
|
30
|
-
* - elementHostStylingMap
|
|
31
|
-
* - elementHostStyleProp
|
|
32
|
-
* - elementHostClassProp
|
|
33
|
-
* - elementHostStylingApply
|
|
25
|
+
* - styling
|
|
26
|
+
* - styleMap
|
|
27
|
+
* - classMap
|
|
28
|
+
* - styleProp
|
|
29
|
+
* - classProp
|
|
30
|
+
* - stylingApply
|
|
34
31
|
*/
|
|
35
32
|
/**
|
|
36
33
|
* Allocates style and class binding properties on the element during creation mode.
|
|
@@ -41,70 +38,54 @@ import { scheduleTick, setInputsForProperty } from './shared';
|
|
|
41
38
|
* values to an element).
|
|
42
39
|
*
|
|
43
40
|
* @param classBindingNames An array containing bindable class names.
|
|
44
|
-
* The `
|
|
41
|
+
* The `classProp` instruction refers to the class name by index in
|
|
45
42
|
* this array (i.e. `['foo', 'bar']` means `foo=0` and `bar=1`).
|
|
46
43
|
* @param styleBindingNames An array containing bindable style properties.
|
|
47
|
-
* The `
|
|
44
|
+
* The `styleProp` instruction refers to the class name by index in
|
|
48
45
|
* this array (i.e. `['width', 'height']` means `width=0` and `height=1`).
|
|
49
46
|
* @param styleSanitizer An optional sanitizer function that will be used to sanitize any CSS
|
|
50
47
|
* style values that are applied to the element (during rendering).
|
|
51
48
|
*
|
|
52
|
-
*
|
|
53
|
-
|
|
54
|
-
export function ɵɵelementStyling(classBindingNames, styleBindingNames, styleSanitizer) {
|
|
55
|
-
var tNode = getPreviousOrParentTNode();
|
|
56
|
-
if (!tNode.stylingTemplate) {
|
|
57
|
-
tNode.stylingTemplate = createEmptyStylingContext();
|
|
58
|
-
}
|
|
59
|
-
// calling the function below ensures that the template's binding values
|
|
60
|
-
// are applied as the first set of bindings into the context. If any other
|
|
61
|
-
// styling bindings are set on the same element (by directives and/or
|
|
62
|
-
// components) then they will be applied at the end of the `elementEnd`
|
|
63
|
-
// instruction (because directives are created first before styling is
|
|
64
|
-
// executed for a new element).
|
|
65
|
-
initElementStyling(tNode, classBindingNames, styleBindingNames, styleSanitizer, DEFAULT_TEMPLATE_DIRECTIVE_INDEX);
|
|
66
|
-
}
|
|
67
|
-
/**
|
|
68
|
-
* Allocates style and class binding properties on the host element during creation mode
|
|
69
|
-
* within the host bindings function of a directive or component.
|
|
70
|
-
*
|
|
71
|
-
* This instruction is meant to be called during creation mode to register all
|
|
72
|
-
* dynamic style and class host bindings on the host element of a directive or
|
|
73
|
-
* component. Note that this is only used for binding values (see `elementHostAttrs`
|
|
74
|
-
* to learn how to assign static styling values to the host element).
|
|
75
|
-
*
|
|
76
|
-
* @param classBindingNames An array containing bindable class names.
|
|
77
|
-
* The `elementHostClassProp` instruction refers to the class name by index in
|
|
78
|
-
* this array (i.e. `['foo', 'bar']` means `foo=0` and `bar=1`).
|
|
79
|
-
* @param styleBindingNames An array containing bindable style properties.
|
|
80
|
-
* The `elementHostStyleProp` instruction refers to the class name by index in
|
|
81
|
-
* this array (i.e. `['width', 'height']` means `width=0` and `height=1`).
|
|
82
|
-
* @param styleSanitizer An optional sanitizer function that will be used to sanitize any CSS
|
|
83
|
-
* style values that are applied to the element (during rendering).
|
|
84
|
-
* Note that the sanitizer instance itself is tied to the provided `directive` and
|
|
85
|
-
* will not be used if the same property is assigned in another directive or
|
|
86
|
-
* on the element directly.
|
|
49
|
+
* Note that this will allocate the provided style/class bindings to the host element if
|
|
50
|
+
* this function is called within a host binding.
|
|
87
51
|
*
|
|
88
52
|
* @codeGenApi
|
|
89
53
|
*/
|
|
90
|
-
export function
|
|
54
|
+
export function ɵɵstyling(classBindingNames, styleBindingNames, styleSanitizer) {
|
|
91
55
|
var tNode = getPreviousOrParentTNode();
|
|
92
56
|
if (!tNode.stylingTemplate) {
|
|
93
57
|
tNode.stylingTemplate = createEmptyStylingContext();
|
|
94
58
|
}
|
|
95
59
|
var directiveStylingIndex = getActiveDirectiveStylingIndex();
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
60
|
+
if (directiveStylingIndex) {
|
|
61
|
+
// this is temporary hack to get the existing styling instructions to
|
|
62
|
+
// play ball with the new refactored implementation.
|
|
63
|
+
// TODO (matsko): remove this once the old implementation is not needed.
|
|
64
|
+
if (runtimeIsNewStylingInUse()) {
|
|
65
|
+
newStylingInit();
|
|
66
|
+
}
|
|
67
|
+
// despite the binding being applied in a queue (below), the allocation
|
|
68
|
+
// of the directive into the context happens right away. The reason for
|
|
69
|
+
// this is to retain the ordering of the directives (which is important
|
|
70
|
+
// for the prioritization of bindings).
|
|
71
|
+
allocateOrUpdateDirectiveIntoContext(tNode.stylingTemplate, directiveStylingIndex);
|
|
72
|
+
var fns = tNode.onElementCreationFns = tNode.onElementCreationFns || [];
|
|
73
|
+
fns.push(function () {
|
|
74
|
+
initStyling(tNode, classBindingNames, styleBindingNames, styleSanitizer, directiveStylingIndex);
|
|
75
|
+
registerHostDirective(tNode.stylingTemplate, directiveStylingIndex);
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
// calling the function below ensures that the template's binding values
|
|
80
|
+
// are applied as the first set of bindings into the context. If any other
|
|
81
|
+
// styling bindings are set on the same element (by directives and/or
|
|
82
|
+
// components) then they will be applied at the end of the `elementEnd`
|
|
83
|
+
// instruction (because directives are created first before styling is
|
|
84
|
+
// executed for a new element).
|
|
85
|
+
initStyling(tNode, classBindingNames, styleBindingNames, styleSanitizer, DEFAULT_TEMPLATE_DIRECTIVE_INDEX);
|
|
86
|
+
}
|
|
106
87
|
}
|
|
107
|
-
function
|
|
88
|
+
function initStyling(tNode, classBindingNames, styleBindingNames, styleSanitizer, directiveStylingIndex) {
|
|
108
89
|
updateContextWithBindings(tNode.stylingTemplate, directiveStylingIndex, classBindingNames, styleBindingNames, styleSanitizer);
|
|
109
90
|
}
|
|
110
91
|
/**
|
|
@@ -112,64 +93,45 @@ function initElementStyling(tNode, classBindingNames, styleBindingNames, styleSa
|
|
|
112
93
|
*
|
|
113
94
|
* If the style value is falsy then it will be removed from the element
|
|
114
95
|
* (or assigned a different value depending if there are any styles placed
|
|
115
|
-
* on the element with `
|
|
116
|
-
* present from when the element was created with `
|
|
96
|
+
* on the element with `styleMap` or any static styles that are
|
|
97
|
+
* present from when the element was created with `styling`).
|
|
117
98
|
*
|
|
118
|
-
* Note that the styling element is updated as part of `
|
|
99
|
+
* Note that the styling element is updated as part of `stylingApply`.
|
|
119
100
|
*
|
|
120
|
-
* @param index Index of the element's with which styling is associated.
|
|
121
101
|
* @param styleIndex Index of style to update. This index value refers to the
|
|
122
102
|
* index of the style in the style bindings array that was passed into
|
|
123
|
-
* `
|
|
124
|
-
* @param value New value to write (falsy to remove).
|
|
125
|
-
* attempts to write to the same binding value (via `elementHostStyleProp`)
|
|
126
|
-
* then it will only be able to do so if the binding value assigned via
|
|
127
|
-
* `elementStyleProp` is falsy (or doesn't exist at all).
|
|
103
|
+
* `styling`.
|
|
104
|
+
* @param value New value to write (falsy to remove).
|
|
128
105
|
* @param suffix Optional suffix. Used with scalar values to add unit such as `px`.
|
|
129
106
|
* Note that when a suffix is provided then the underlying sanitizer will
|
|
130
107
|
* be ignored.
|
|
131
108
|
* @param forceOverride Whether or not to update the styling value immediately
|
|
132
109
|
* (despite the other bindings possibly having priority)
|
|
133
110
|
*
|
|
111
|
+
* Note that this will apply the provided style value to the host element if this function is called
|
|
112
|
+
* within a host binding.
|
|
113
|
+
*
|
|
134
114
|
* @codeGenApi
|
|
135
115
|
*/
|
|
136
|
-
export function
|
|
116
|
+
export function ɵɵstyleProp(styleIndex, value, suffix, forceOverride) {
|
|
117
|
+
var index = getSelectedIndex();
|
|
137
118
|
var valueToAdd = resolveStylePropValue(value, suffix);
|
|
138
119
|
var stylingContext = getStylingContext(index, getLView());
|
|
139
|
-
updateElementStyleProp(stylingContext, styleIndex, valueToAdd, DEFAULT_TEMPLATE_DIRECTIVE_INDEX, forceOverride);
|
|
140
|
-
}
|
|
141
|
-
/**
|
|
142
|
-
* Update a host style binding value on the host element within a component/directive.
|
|
143
|
-
*
|
|
144
|
-
* If the style value is falsy then it will be removed from the host element
|
|
145
|
-
* (or assigned a different value depending if there are any styles placed
|
|
146
|
-
* on the same element with `elementHostStylingMap` or any static styles that
|
|
147
|
-
* are present from when the element was patched with `elementHostStyling`).
|
|
148
|
-
*
|
|
149
|
-
* Note that the styling applied to the host element once
|
|
150
|
-
* `elementHostStylingApply` is called.
|
|
151
|
-
*
|
|
152
|
-
* @param styleIndex Index of style to update. This index value refers to the
|
|
153
|
-
* index of the style in the style bindings array that was passed into
|
|
154
|
-
* `elementHostStyling`.
|
|
155
|
-
* @param value New value to write (falsy to remove). The value may or may not
|
|
156
|
-
* be applied to the element depending on the template/component/directive
|
|
157
|
-
* prioritization (see `interfaces/styling.ts`)
|
|
158
|
-
* @param suffix Optional suffix. Used with scalar values to add unit such as `px`.
|
|
159
|
-
* Note that when a suffix is provided then the underlying sanitizer will
|
|
160
|
-
* be ignored.
|
|
161
|
-
* @param forceOverride Whether or not to update the styling value immediately
|
|
162
|
-
* (despite the other bindings possibly having priority)
|
|
163
|
-
*
|
|
164
|
-
* @codeGenApi
|
|
165
|
-
*/
|
|
166
|
-
export function ɵɵelementHostStyleProp(styleIndex, value, suffix, forceOverride) {
|
|
167
120
|
var directiveStylingIndex = getActiveDirectiveStylingIndex();
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
121
|
+
if (directiveStylingIndex) {
|
|
122
|
+
var args = [stylingContext, styleIndex, valueToAdd, directiveStylingIndex, forceOverride];
|
|
123
|
+
enqueueHostInstruction(stylingContext, directiveStylingIndex, updatestyleProp, args);
|
|
124
|
+
}
|
|
125
|
+
else {
|
|
126
|
+
updatestyleProp(stylingContext, styleIndex, valueToAdd, DEFAULT_TEMPLATE_DIRECTIVE_INDEX, forceOverride);
|
|
127
|
+
}
|
|
128
|
+
if (runtimeIsNewStylingInUse()) {
|
|
129
|
+
var prop = getBindingNameFromIndex(stylingContext, styleIndex, directiveStylingIndex, false);
|
|
130
|
+
// the reason why we cast the value as `boolean` is
|
|
131
|
+
// because the new styling refactor does not yet support
|
|
132
|
+
// sanitization or animation players.
|
|
133
|
+
newStyleProp(prop, value, suffix);
|
|
134
|
+
}
|
|
173
135
|
}
|
|
174
136
|
function resolveStylePropValue(value, suffix) {
|
|
175
137
|
var valueToAdd = null;
|
|
@@ -194,53 +156,42 @@ function resolveStylePropValue(value, suffix) {
|
|
|
194
156
|
*
|
|
195
157
|
* This instruction is meant to handle the `[class.foo]="exp"` case and,
|
|
196
158
|
* therefore, the class binding itself must already be allocated using
|
|
197
|
-
* `
|
|
159
|
+
* `styling` within the creation block.
|
|
198
160
|
*
|
|
199
|
-
* @param index Index of the element's with which styling is associated.
|
|
200
161
|
* @param classIndex Index of class to toggle. This index value refers to the
|
|
201
162
|
* index of the class in the class bindings array that was passed into
|
|
202
|
-
* `
|
|
163
|
+
* `styling` (which is meant to be called before this
|
|
203
164
|
* function is).
|
|
204
165
|
* @param value A true/false value which will turn the class on or off.
|
|
205
166
|
* @param forceOverride Whether or not this value will be applied regardless
|
|
206
167
|
* of where it is being set within the styling priority structure.
|
|
207
168
|
*
|
|
208
|
-
*
|
|
209
|
-
|
|
210
|
-
export function ɵɵelementClassProp(index, classIndex, value, forceOverride) {
|
|
211
|
-
var input = (value instanceof BoundPlayerFactory) ?
|
|
212
|
-
value :
|
|
213
|
-
booleanOrNull(value);
|
|
214
|
-
var stylingContext = getStylingContext(index, getLView());
|
|
215
|
-
updateElementClassProp(stylingContext, classIndex, input, DEFAULT_TEMPLATE_DIRECTIVE_INDEX, forceOverride);
|
|
216
|
-
}
|
|
217
|
-
/**
|
|
218
|
-
* Update a class host binding for a directive's/component's host element within
|
|
219
|
-
* the host bindings function.
|
|
220
|
-
*
|
|
221
|
-
* This instruction is meant to handle the `@HostBinding('class.foo')` case and,
|
|
222
|
-
* therefore, the class binding itself must already be allocated using
|
|
223
|
-
* `elementHostStyling` within the creation block.
|
|
224
|
-
*
|
|
225
|
-
* @param classIndex Index of class to toggle. This index value refers to the
|
|
226
|
-
* index of the class in the class bindings array that was passed into
|
|
227
|
-
* `elementHostStlying` (which is meant to be called before this
|
|
228
|
-
* function is).
|
|
229
|
-
* @param value A true/false value which will turn the class on or off.
|
|
230
|
-
* @param forceOverride Whether or not this value will be applied regardless
|
|
231
|
-
* of where it is being set within the stylings priority structure.
|
|
169
|
+
* Note that this will apply the provided class value to the host element if this function
|
|
170
|
+
* is called within a host binding.
|
|
232
171
|
*
|
|
233
172
|
* @codeGenApi
|
|
234
173
|
*/
|
|
235
|
-
export function
|
|
236
|
-
var
|
|
237
|
-
var hostElementIndex = getSelectedIndex();
|
|
238
|
-
var stylingContext = getStylingContext(hostElementIndex, getLView());
|
|
174
|
+
export function ɵɵclassProp(classIndex, value, forceOverride) {
|
|
175
|
+
var index = getSelectedIndex();
|
|
239
176
|
var input = (value instanceof BoundPlayerFactory) ?
|
|
240
177
|
value :
|
|
241
178
|
booleanOrNull(value);
|
|
242
|
-
var
|
|
243
|
-
|
|
179
|
+
var directiveStylingIndex = getActiveDirectiveStylingIndex();
|
|
180
|
+
var stylingContext = getStylingContext(index, getLView());
|
|
181
|
+
if (directiveStylingIndex) {
|
|
182
|
+
var args = [stylingContext, classIndex, input, directiveStylingIndex, forceOverride];
|
|
183
|
+
enqueueHostInstruction(stylingContext, directiveStylingIndex, updateclassProp, args);
|
|
184
|
+
}
|
|
185
|
+
else {
|
|
186
|
+
updateclassProp(stylingContext, classIndex, input, DEFAULT_TEMPLATE_DIRECTIVE_INDEX, forceOverride);
|
|
187
|
+
}
|
|
188
|
+
if (runtimeIsNewStylingInUse()) {
|
|
189
|
+
var prop = getBindingNameFromIndex(stylingContext, classIndex, directiveStylingIndex, true);
|
|
190
|
+
// the reason why we cast the value as `boolean` is
|
|
191
|
+
// because the new styling refactor does not yet support
|
|
192
|
+
// sanitization or animation players.
|
|
193
|
+
newClassProp(prop, input);
|
|
194
|
+
}
|
|
244
195
|
}
|
|
245
196
|
function booleanOrNull(value) {
|
|
246
197
|
if (typeof value === 'boolean')
|
|
@@ -248,104 +199,106 @@ function booleanOrNull(value) {
|
|
|
248
199
|
return value ? true : null;
|
|
249
200
|
}
|
|
250
201
|
/**
|
|
251
|
-
* Update style
|
|
202
|
+
* Update style bindings using an object literal on an element.
|
|
252
203
|
*
|
|
253
|
-
* This instruction is meant to apply styling via the `[style]="exp"`
|
|
254
|
-
*
|
|
255
|
-
*
|
|
256
|
-
*
|
|
204
|
+
* This instruction is meant to apply styling via the `[style]="exp"` template bindings.
|
|
205
|
+
* When styles are applied to the element they will then be updated with respect to
|
|
206
|
+
* any styles/classes set via `styleProp`. If any styles are set to falsy
|
|
207
|
+
* then they will be removed from the element.
|
|
257
208
|
*
|
|
258
|
-
* Note that the styling instruction will not be applied until `
|
|
209
|
+
* Note that the styling instruction will not be applied until `stylingApply` is called.
|
|
259
210
|
*
|
|
260
|
-
* @param index Index of the element's with which styling is associated.
|
|
261
|
-
* @param classes A key/value map or string of CSS classes that will be added to the
|
|
262
|
-
* given element. Any missing classes (that have already been applied to the element
|
|
263
|
-
* beforehand) will be removed (unset) from the element's list of CSS classes.
|
|
264
211
|
* @param styles A key/value style map of the styles that will be applied to the given element.
|
|
265
212
|
* Any missing styles (that have already been applied to the element beforehand) will be
|
|
266
213
|
* removed (unset) from the element's styling.
|
|
267
214
|
*
|
|
215
|
+
* Note that this will apply the provided styleMap value to the host element if this function
|
|
216
|
+
* is called within a host binding.
|
|
217
|
+
*
|
|
268
218
|
* @codeGenApi
|
|
269
219
|
*/
|
|
270
|
-
export function
|
|
220
|
+
export function ɵɵstyleMap(styles) {
|
|
221
|
+
var index = getSelectedIndex();
|
|
271
222
|
var lView = getLView();
|
|
272
223
|
var stylingContext = getStylingContext(index, lView);
|
|
273
|
-
var
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
var
|
|
280
|
-
|
|
281
|
-
|
|
224
|
+
var directiveStylingIndex = getActiveDirectiveStylingIndex();
|
|
225
|
+
if (directiveStylingIndex) {
|
|
226
|
+
var args = [stylingContext, styles, directiveStylingIndex];
|
|
227
|
+
enqueueHostInstruction(stylingContext, directiveStylingIndex, updateStyleMap, args);
|
|
228
|
+
}
|
|
229
|
+
else {
|
|
230
|
+
var tNode = getTNode(index, lView);
|
|
231
|
+
// inputs are only evaluated from a template binding into a directive, therefore,
|
|
232
|
+
// there should not be a situation where a directive host bindings function
|
|
233
|
+
// evaluates the inputs (this should only happen in the template function)
|
|
234
|
+
if (hasStyleInput(tNode) && styles !== NO_CHANGE) {
|
|
235
|
+
var initialStyles = getInitialClassNameValue(stylingContext);
|
|
236
|
+
var styleInputVal = (initialStyles.length ? (initialStyles + ' ') : '') + forceStylesAsString(styles);
|
|
237
|
+
setInputsForProperty(lView, tNode.inputs['style'], styleInputVal);
|
|
238
|
+
styles = NO_CHANGE;
|
|
239
|
+
}
|
|
240
|
+
updateStyleMap(stylingContext, styles);
|
|
282
241
|
}
|
|
283
|
-
if (
|
|
284
|
-
|
|
285
|
-
var styleInputVal = (initialStyles.length ? (initialStyles + ' ') : '') + forceStylesAsString(styles);
|
|
286
|
-
setInputsForProperty(lView, tNode.inputs['style'], styleInputVal);
|
|
287
|
-
styles = NO_CHANGE;
|
|
242
|
+
if (runtimeIsNewStylingInUse()) {
|
|
243
|
+
newStyleMap(styles);
|
|
288
244
|
}
|
|
289
|
-
updateStylingMap(stylingContext, classes, styles);
|
|
290
245
|
}
|
|
291
246
|
/**
|
|
292
|
-
* Update
|
|
293
|
-
* bindings function for a directive/component.
|
|
247
|
+
* Update class bindings using an object literal or class-string on an element.
|
|
294
248
|
*
|
|
295
|
-
* This instruction is meant to apply styling via the
|
|
296
|
-
*
|
|
297
|
-
*
|
|
298
|
-
*
|
|
299
|
-
* `elementHostClassProp`. If any styles or classes are set to falsy then they
|
|
300
|
-
* will be removed from the element.
|
|
249
|
+
* This instruction is meant to apply styling via the `[class]="exp"` template bindings.
|
|
250
|
+
* When classes are applied to the element they will then be updated with
|
|
251
|
+
* respect to any styles/classes set via `classProp`. If any
|
|
252
|
+
* classes are set to falsy then they will be removed from the element.
|
|
301
253
|
*
|
|
302
|
-
* Note that the styling instruction will not be applied until
|
|
303
|
-
*
|
|
254
|
+
* Note that the styling instruction will not be applied until `stylingApply` is called.
|
|
255
|
+
* Note that this will the provided classMap value to the host element if this function is called
|
|
256
|
+
* within a host binding.
|
|
304
257
|
*
|
|
305
258
|
* @param classes A key/value map or string of CSS classes that will be added to the
|
|
306
259
|
* given element. Any missing classes (that have already been applied to the element
|
|
307
260
|
* beforehand) will be removed (unset) from the element's list of CSS classes.
|
|
308
|
-
* @param styles A key/value style map of the styles that will be applied to the given element.
|
|
309
|
-
* Any missing styles (that have already been applied to the element beforehand) will be
|
|
310
|
-
* removed (unset) from the element's styling.
|
|
311
261
|
*
|
|
312
262
|
* @codeGenApi
|
|
313
263
|
*/
|
|
314
|
-
export function
|
|
264
|
+
export function ɵɵclassMap(classes) {
|
|
265
|
+
var index = getSelectedIndex();
|
|
266
|
+
var lView = getLView();
|
|
267
|
+
var stylingContext = getStylingContext(index, lView);
|
|
315
268
|
var directiveStylingIndex = getActiveDirectiveStylingIndex();
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
269
|
+
if (directiveStylingIndex) {
|
|
270
|
+
var args = [stylingContext, classes, directiveStylingIndex];
|
|
271
|
+
enqueueHostInstruction(stylingContext, directiveStylingIndex, updateClassMap, args);
|
|
272
|
+
}
|
|
273
|
+
else {
|
|
274
|
+
var tNode = getTNode(index, lView);
|
|
275
|
+
// inputs are only evaluated from a template binding into a directive, therefore,
|
|
276
|
+
// there should not be a situation where a directive host bindings function
|
|
277
|
+
// evaluates the inputs (this should only happen in the template function)
|
|
278
|
+
if (hasClassInput(tNode) && classes !== NO_CHANGE) {
|
|
279
|
+
var initialClasses = getInitialClassNameValue(stylingContext);
|
|
280
|
+
var classInputVal = (initialClasses.length ? (initialClasses + ' ') : '') + forceClassesAsString(classes);
|
|
281
|
+
setInputsForProperty(lView, tNode.inputs['class'], classInputVal);
|
|
282
|
+
classes = NO_CHANGE;
|
|
283
|
+
}
|
|
284
|
+
updateClassMap(stylingContext, classes);
|
|
285
|
+
}
|
|
286
|
+
if (runtimeIsNewStylingInUse()) {
|
|
287
|
+
newClassMap(classes);
|
|
288
|
+
}
|
|
320
289
|
}
|
|
321
290
|
/**
|
|
322
291
|
* Apply all style and class binding values to the element.
|
|
323
292
|
*
|
|
324
|
-
* This instruction is meant to be run after `
|
|
325
|
-
* or `
|
|
326
|
-
* the element if any styling bindings have been updated.
|
|
327
|
-
*
|
|
328
|
-
* @param index Index of the element's with which styling is associated.
|
|
293
|
+
* This instruction is meant to be run after `styleMap`, `classMap`,
|
|
294
|
+
* `styleProp` or `classProp` instructions have been run and will
|
|
295
|
+
* only apply styling to the element if any styling bindings have been updated.
|
|
329
296
|
*
|
|
330
297
|
* @codeGenApi
|
|
331
298
|
*/
|
|
332
|
-
export function
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
/**
|
|
336
|
-
* Apply all style and class host binding values to the element.
|
|
337
|
-
*
|
|
338
|
-
* This instruction is meant to be run after `elementHostStylingMap`,
|
|
339
|
-
* `elementHostStyleProp` or `elementHostClassProp` instructions have
|
|
340
|
-
* been run and will only apply styling to the host element if any
|
|
341
|
-
* styling bindings have been updated.
|
|
342
|
-
*
|
|
343
|
-
* @codeGenApi
|
|
344
|
-
*/
|
|
345
|
-
export function ɵɵelementHostStylingApply() {
|
|
346
|
-
elementStylingApplyInternal(getActiveDirectiveStylingIndex(), getSelectedIndex());
|
|
347
|
-
}
|
|
348
|
-
export function elementStylingApplyInternal(directiveStylingIndex, index) {
|
|
299
|
+
export function ɵɵstylingApply() {
|
|
300
|
+
var index = getSelectedIndex();
|
|
301
|
+
var directiveStylingIndex = getActiveDirectiveStylingIndex() || DEFAULT_TEMPLATE_DIRECTIVE_INDEX;
|
|
349
302
|
var lView = getLView();
|
|
350
303
|
var tNode = getTNode(index, lView);
|
|
351
304
|
// if a non-element value is being processed then we can't render values
|
|
@@ -354,10 +307,12 @@ export function elementStylingApplyInternal(directiveStylingIndex, index) {
|
|
|
354
307
|
var renderer = tNode.type === 3 /* Element */ ? lView[RENDERER] : null;
|
|
355
308
|
var isFirstRender = (lView[FLAGS] & 8 /* FirstLViewPass */) !== 0;
|
|
356
309
|
var stylingContext = getStylingContext(index, lView);
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
310
|
+
if (runtimeAllowOldStyling()) {
|
|
311
|
+
var totalPlayersQueued = renderStyling(stylingContext, renderer, lView, isFirstRender, null, null, directiveStylingIndex);
|
|
312
|
+
if (totalPlayersQueued > 0) {
|
|
313
|
+
var rootContext = getRootContext(lView);
|
|
314
|
+
scheduleTick(rootContext, 2 /* FlushPlayers */);
|
|
315
|
+
}
|
|
361
316
|
}
|
|
362
317
|
// because select(n) may not run between every instruction, the cached styling
|
|
363
318
|
// context may not get cleared between elements. The reason for this is because
|
|
@@ -367,6 +322,9 @@ export function elementStylingApplyInternal(directiveStylingIndex, index) {
|
|
|
367
322
|
// cleared because there is no code in Angular that applies more styling code after a
|
|
368
323
|
// styling flush has occurred. Note that this will be fixed once FW-1254 lands.
|
|
369
324
|
setCachedStylingContext(null);
|
|
325
|
+
if (runtimeIsNewStylingInUse()) {
|
|
326
|
+
newStylingApply();
|
|
327
|
+
}
|
|
370
328
|
}
|
|
371
329
|
export function getActiveDirectiveStylingIndex() {
|
|
372
330
|
// whenever a directive's hostBindings function is called a uniqueId value
|
|
@@ -389,4 +347,4 @@ function getStylingContext(index, lView) {
|
|
|
389
347
|
}
|
|
390
348
|
return context;
|
|
391
349
|
}
|
|
392
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"styling.js","sourceRoot":"","sources":["../../../../../../../../../../../packages/core/src/render3/instructions/styling.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 {StyleSanitizeFn} from '../../sanitization/style_sanitizer';\nimport {assertEqual} from '../../util/assert';\nimport {TNode, TNodeType} from '../interfaces/node';\nimport {PlayerFactory} from '../interfaces/player';\nimport {FLAGS, HEADER_OFFSET, LView, LViewFlags, RENDERER, RootContextFlags} from '../interfaces/view';\nimport {getActiveDirectiveId, getActiveDirectiveSuperClassDepth, getLView, getPreviousOrParentTNode, getSelectedIndex} from '../state';\nimport {getInitialClassNameValue, renderStyling, updateClassProp as updateElementClassProp, updateContextWithBindings, updateStyleProp as updateElementStyleProp, updateStylingMap} from '../styling/class_and_style_bindings';\nimport {ParamsOf, enqueueHostInstruction, registerHostDirective} from '../styling/host_instructions_queue';\nimport {BoundPlayerFactory} from '../styling/player_factory';\nimport {DEFAULT_TEMPLATE_DIRECTIVE_INDEX} from '../styling/shared';\nimport {getCachedStylingContext, setCachedStylingContext} from '../styling/state';\nimport {allocateOrUpdateDirectiveIntoContext, createEmptyStylingContext, forceClassesAsString, forceStylesAsString, getStylingContextFromLView, hasClassInput, hasStyleInput} from '../styling/util';\nimport {NO_CHANGE} from '../tokens';\nimport {renderStringify} from '../util/misc_utils';\nimport {getRootContext} from '../util/view_traversal_utils';\nimport {getTNode} from '../util/view_utils';\n\nimport {scheduleTick, setInputsForProperty} from './shared';\n\n\n\n/*\n * The contents of this file include the instructions for all styling-related\n * operations in Angular.\n *\n * The instructions present in this file are:\n *\n * Template level styling instructions:\n * - elementStyling\n * - elementStylingMap\n * - elementStyleProp\n * - elementClassProp\n * - elementStylingApply\n *\n * Host bindings level styling instructions:\n * - elementHostStyling\n * - elementHostStylingMap\n * - elementHostStyleProp\n * - elementHostClassProp\n * - elementHostStylingApply\n */\n\n/**\n * Allocates style and class binding properties on the element during creation mode.\n *\n * This instruction is meant to be called during creation mode to register all\n * dynamic style and class bindings on the element. Note that this is only used\n * for binding values (see `elementStart` to learn how to assign static styling\n * values to an element).\n *\n * @param classBindingNames An array containing bindable class names.\n *        The `elementClassProp` instruction refers to the class name by index in\n *        this array (i.e. `['foo', 'bar']` means `foo=0` and `bar=1`).\n * @param styleBindingNames An array containing bindable style properties.\n *        The `elementStyleProp` instruction refers to the class name by index in\n *        this array (i.e. `['width', 'height']` means `width=0` and `height=1`).\n * @param styleSanitizer An optional sanitizer function that will be used to sanitize any CSS\n *        style values that are applied to the element (during rendering).\n *\n * @codeGenApi\n */\nexport function ɵɵelementStyling(\n    classBindingNames?: string[] | null, styleBindingNames?: string[] | null,\n    styleSanitizer?: StyleSanitizeFn | null): void {\n  const tNode = getPreviousOrParentTNode();\n  if (!tNode.stylingTemplate) {\n    tNode.stylingTemplate = createEmptyStylingContext();\n  }\n\n  // calling the function below ensures that the template's binding values\n  // are applied as the first set of bindings into the context. If any other\n  // styling bindings are set on the same element (by directives and/or\n  // components) then they will be applied at the end of the `elementEnd`\n  // instruction (because directives are created first before styling is\n  // executed for a new element).\n  initElementStyling(\n      tNode, classBindingNames, styleBindingNames, styleSanitizer,\n      DEFAULT_TEMPLATE_DIRECTIVE_INDEX);\n}\n\n/**\n * Allocates style and class binding properties on the host element during creation mode\n * within the host bindings function of a directive or component.\n *\n * This instruction is meant to be called during creation mode to register all\n * dynamic style and class host bindings on the host element of a directive or\n * component. Note that this is only used for binding values (see `elementHostAttrs`\n * to learn how to assign static styling values to the host element).\n *\n * @param classBindingNames An array containing bindable class names.\n *        The `elementHostClassProp` instruction refers to the class name by index in\n *        this array (i.e. `['foo', 'bar']` means `foo=0` and `bar=1`).\n * @param styleBindingNames An array containing bindable style properties.\n *        The `elementHostStyleProp` instruction refers to the class name by index in\n *        this array (i.e. `['width', 'height']` means `width=0` and `height=1`).\n * @param styleSanitizer An optional sanitizer function that will be used to sanitize any CSS\n *        style values that are applied to the element (during rendering).\n *        Note that the sanitizer instance itself is tied to the provided `directive` and\n *        will not be used if the same property is assigned in another directive or\n *        on the element directly.\n *\n * @codeGenApi\n */\nexport function ɵɵelementHostStyling(\n    classBindingNames?: string[] | null, styleBindingNames?: string[] | null,\n    styleSanitizer?: StyleSanitizeFn | null): void {\n  const tNode = getPreviousOrParentTNode();\n  if (!tNode.stylingTemplate) {\n    tNode.stylingTemplate = createEmptyStylingContext();\n  }\n\n  const directiveStylingIndex = getActiveDirectiveStylingIndex();\n\n  // despite the binding being applied in a queue (below), the allocation\n  // of the directive into the context happens right away. The reason for\n  // this is to retain the ordering of the directives (which is important\n  // for the prioritization of bindings).\n  allocateOrUpdateDirectiveIntoContext(tNode.stylingTemplate, directiveStylingIndex);\n\n  const fns = tNode.onElementCreationFns = tNode.onElementCreationFns || [];\n  fns.push(() => {\n    initElementStyling(\n        tNode, classBindingNames, styleBindingNames, styleSanitizer, directiveStylingIndex);\n    registerHostDirective(tNode.stylingTemplate !, directiveStylingIndex);\n  });\n}\n\nfunction initElementStyling(\n    tNode: TNode, classBindingNames: string[] | null | undefined,\n    styleBindingNames: string[] | null | undefined,\n    styleSanitizer: StyleSanitizeFn | null | undefined, directiveStylingIndex: number): void {\n  updateContextWithBindings(\n      tNode.stylingTemplate !, directiveStylingIndex, classBindingNames, styleBindingNames,\n      styleSanitizer);\n}\n\n\n/**\n * Update a style binding on an element with the provided value.\n *\n * If the style value is falsy then it will be removed from the element\n * (or assigned a different value depending if there are any styles placed\n * on the element with `elementStylingMap` or any static styles that are\n * present from when the element was created with `elementStyling`).\n *\n * Note that the styling element is updated as part of `elementStylingApply`.\n *\n * @param index Index of the element's with which styling is associated.\n * @param styleIndex Index of style to update. This index value refers to the\n *        index of the style in the style bindings array that was passed into\n *        `elementStyling`.\n * @param value New value to write (falsy to remove). Note that if a directive also\n *        attempts to write to the same binding value (via `elementHostStyleProp`)\n *        then it will only be able to do so if the binding value assigned via\n *        `elementStyleProp` is falsy (or doesn't exist at all).\n * @param suffix Optional suffix. Used with scalar values to add unit such as `px`.\n *        Note that when a suffix is provided then the underlying sanitizer will\n *        be ignored.\n * @param forceOverride Whether or not to update the styling value immediately\n *        (despite the other bindings possibly having priority)\n *\n * @codeGenApi\n */\nexport function ɵɵelementStyleProp(\n    index: number, styleIndex: number, value: string | number | String | PlayerFactory | null,\n    suffix?: string | null, forceOverride?: boolean): void {\n  const valueToAdd = resolveStylePropValue(value, suffix);\n  const stylingContext = getStylingContext(index, getLView());\n  updateElementStyleProp(\n      stylingContext, styleIndex, valueToAdd, DEFAULT_TEMPLATE_DIRECTIVE_INDEX, forceOverride);\n}\n\n/**\n * Update a host style binding value on the host element within a component/directive.\n *\n * If the style value is falsy then it will be removed from the host element\n * (or assigned a different value depending if there are any styles placed\n * on the same element with `elementHostStylingMap` or any static styles that\n * are present from when the element was patched with `elementHostStyling`).\n *\n * Note that the styling applied to the host element once\n * `elementHostStylingApply` is called.\n *\n * @param styleIndex Index of style to update. This index value refers to the\n *        index of the style in the style bindings array that was passed into\n *        `elementHostStyling`.\n * @param value New value to write (falsy to remove). The value may or may not\n *        be applied to the element depending on the template/component/directive\n *        prioritization (see `interfaces/styling.ts`)\n * @param suffix Optional suffix. Used with scalar values to add unit such as `px`.\n *        Note that when a suffix is provided then the underlying sanitizer will\n *        be ignored.\n * @param forceOverride Whether or not to update the styling value immediately\n *        (despite the other bindings possibly having priority)\n *\n * @codeGenApi\n */\nexport function ɵɵelementHostStyleProp(\n    styleIndex: number, value: string | number | String | PlayerFactory | null,\n    suffix?: string | null, forceOverride?: boolean): void {\n  const directiveStylingIndex = getActiveDirectiveStylingIndex();\n  const hostElementIndex = getSelectedIndex();\n\n  const stylingContext = getStylingContext(hostElementIndex, getLView());\n  const valueToAdd = resolveStylePropValue(value, suffix);\n  const args: ParamsOf<typeof updateElementStyleProp> =\n      [stylingContext, styleIndex, valueToAdd, directiveStylingIndex, forceOverride];\n  enqueueHostInstruction(stylingContext, directiveStylingIndex, updateElementStyleProp, args);\n}\n\nfunction resolveStylePropValue(\n    value: string | number | String | PlayerFactory | null, suffix: string | null | undefined) {\n  let valueToAdd: string|null = null;\n  if (value !== null) {\n    if (suffix) {\n      // when a suffix is applied then it will bypass\n      // sanitization entirely (b/c a new string is created)\n      valueToAdd = renderStringify(value) + suffix;\n    } else {\n      // sanitization happens by dealing with a String value\n      // this means that the string value will be passed through\n      // into the style rendering later (which is where the value\n      // will be sanitized before it is applied)\n      valueToAdd = value as any as string;\n    }\n  }\n  return valueToAdd;\n}\n\n\n/**\n * Update a class binding on an element with the provided value.\n *\n * This instruction is meant to handle the `[class.foo]=\"exp\"` case and,\n * therefore, the class binding itself must already be allocated using\n * `elementStyling` within the creation block.\n *\n * @param index Index of the element's with which styling is associated.\n * @param classIndex Index of class to toggle. This index value refers to the\n *        index of the class in the class bindings array that was passed into\n *        `elementStyling` (which is meant to be called before this\n *        function is).\n * @param value A true/false value which will turn the class on or off.\n * @param forceOverride Whether or not this value will be applied regardless\n *        of where it is being set within the styling priority structure.\n *\n * @codeGenApi\n */\nexport function ɵɵelementClassProp(\n    index: number, classIndex: number, value: boolean | PlayerFactory,\n    forceOverride?: boolean): void {\n  const input = (value instanceof BoundPlayerFactory) ?\n      (value as BoundPlayerFactory<boolean|null>) :\n      booleanOrNull(value);\n  const stylingContext = getStylingContext(index, getLView());\n  updateElementClassProp(\n      stylingContext, classIndex, input, DEFAULT_TEMPLATE_DIRECTIVE_INDEX, forceOverride);\n}\n\n\n/**\n * Update a class host binding for a directive's/component's host element within\n * the host bindings function.\n *\n * This instruction is meant to handle the `@HostBinding('class.foo')` case and,\n * therefore, the class binding itself must already be allocated using\n * `elementHostStyling` within the creation block.\n *\n * @param classIndex Index of class to toggle. This index value refers to the\n *        index of the class in the class bindings array that was passed into\n *        `elementHostStlying` (which is meant to be called before this\n *        function is).\n * @param value A true/false value which will turn the class on or off.\n * @param forceOverride Whether or not this value will be applied regardless\n *        of where it is being set within the stylings priority structure.\n *\n * @codeGenApi\n */\nexport function ɵɵelementHostClassProp(\n    classIndex: number, value: boolean | PlayerFactory, forceOverride?: boolean): void {\n  const directiveStylingIndex = getActiveDirectiveStylingIndex();\n  const hostElementIndex = getSelectedIndex();\n  const stylingContext = getStylingContext(hostElementIndex, getLView());\n\n  const input = (value instanceof BoundPlayerFactory) ?\n      (value as BoundPlayerFactory<boolean|null>) :\n      booleanOrNull(value);\n\n  const args: ParamsOf<typeof updateElementClassProp> =\n      [stylingContext, classIndex, input, directiveStylingIndex, forceOverride];\n  enqueueHostInstruction(stylingContext, directiveStylingIndex, updateElementClassProp, args);\n}\n\nfunction booleanOrNull(value: any): boolean|null {\n  if (typeof value === 'boolean') return value;\n  return value ? true : null;\n}\n\n\n/**\n * Update style and/or class bindings using object literals on an element.\n *\n * This instruction is meant to apply styling via the `[style]=\"exp\"` and `[class]=\"exp\"` template\n * bindings. When styles/classes are applied to the element they will then be updated with\n * respect to any styles/classes set with `elementStyleProp` or `elementClassProp`. If any\n * styles or classes are set to falsy then they will be removed from the element.\n *\n * Note that the styling instruction will not be applied until `elementStylingApply` is called.\n *\n * @param index Index of the element's with which styling is associated.\n * @param classes A key/value map or string of CSS classes that will be added to the\n *        given element. Any missing classes (that have already been applied to the element\n *        beforehand) will be removed (unset) from the element's list of CSS classes.\n * @param styles A key/value style map of the styles that will be applied to the given element.\n *        Any missing styles (that have already been applied to the element beforehand) will be\n *        removed (unset) from the element's styling.\n *\n * @codeGenApi\n */\nexport function ɵɵelementStylingMap(\n    index: number, classes: {[key: string]: any} | string | NO_CHANGE | null,\n    styles?: {[styleName: string]: any} | NO_CHANGE | null): void {\n  const lView = getLView();\n  const stylingContext = getStylingContext(index, lView);\n  const tNode = getTNode(index, lView);\n\n  // inputs are only evaluated from a template binding into a directive, therefore,\n  // there should not be a situation where a directive host bindings function\n  // evaluates the inputs (this should only happen in the template function)\n  if (hasClassInput(tNode) && classes !== NO_CHANGE) {\n    const initialClasses = getInitialClassNameValue(stylingContext);\n    const classInputVal =\n        (initialClasses.length ? (initialClasses + ' ') : '') + forceClassesAsString(classes);\n    setInputsForProperty(lView, tNode.inputs !['class'] !, classInputVal);\n    classes = NO_CHANGE;\n  }\n\n  if (hasStyleInput(tNode) && styles !== NO_CHANGE) {\n    const initialStyles = getInitialClassNameValue(stylingContext);\n    const styleInputVal =\n        (initialStyles.length ? (initialStyles + ' ') : '') + forceStylesAsString(styles);\n    setInputsForProperty(lView, tNode.inputs !['style'] !, styleInputVal);\n    styles = NO_CHANGE;\n  }\n\n  updateStylingMap(stylingContext, classes, styles);\n}\n\n\n/**\n * Update style and/or class host bindings using object literals on an element within the host\n * bindings function for a directive/component.\n *\n * This instruction is meant to apply styling via the `@HostBinding('style')` and\n * `@HostBinding('class')` bindings for a component's or directive's host element.\n * When styles/classes are applied to the host element they will then be updated\n * with respect to any styles/classes set with `elementHostStyleProp` or\n * `elementHostClassProp`. If any styles or classes are set to falsy then they\n * will be removed from the element.\n *\n * Note that the styling instruction will not be applied until\n * `elementHostStylingApply` is called.\n *\n * @param classes A key/value map or string of CSS classes that will be added to the\n *        given element. Any missing classes (that have already been applied to the element\n *        beforehand) will be removed (unset) from the element's list of CSS classes.\n * @param styles A key/value style map of the styles that will be applied to the given element.\n *        Any missing styles (that have already been applied to the element beforehand) will be\n *        removed (unset) from the element's styling.\n *\n * @codeGenApi\n */\nexport function ɵɵelementHostStylingMap(\n    classes: {[key: string]: any} | string | NO_CHANGE | null,\n    styles?: {[styleName: string]: any} | NO_CHANGE | null): void {\n  const directiveStylingIndex = getActiveDirectiveStylingIndex();\n  const hostElementIndex = getSelectedIndex();\n  const stylingContext = getStylingContext(hostElementIndex, getLView());\n  const args: ParamsOf<typeof updateStylingMap> =\n      [stylingContext, classes, styles, directiveStylingIndex];\n  enqueueHostInstruction(stylingContext, directiveStylingIndex, updateStylingMap, args);\n}\n\n\n/**\n * Apply all style and class binding values to the element.\n *\n * This instruction is meant to be run after `elementStylingMap`, `elementStyleProp`\n * or `elementClassProp` instructions have been run and will only apply styling to\n * the element if any styling bindings have been updated.\n *\n * @param index Index of the element's with which styling is associated.\n *\n * @codeGenApi\n */\nexport function ɵɵelementStylingApply(index: number): void {\n  elementStylingApplyInternal(DEFAULT_TEMPLATE_DIRECTIVE_INDEX, index);\n}\n\n/**\n * Apply all style and class host binding values to the element.\n *\n * This instruction is meant to be run after `elementHostStylingMap`,\n * `elementHostStyleProp` or `elementHostClassProp` instructions have\n * been run and will only apply styling to the host element if any\n * styling bindings have been updated.\n *\n * @codeGenApi\n */\nexport function ɵɵelementHostStylingApply(): void {\n  elementStylingApplyInternal(getActiveDirectiveStylingIndex(), getSelectedIndex());\n}\n\nexport function elementStylingApplyInternal(directiveStylingIndex: number, index: number): void {\n  const lView = getLView();\n  const tNode = getTNode(index, lView);\n\n  // if a non-element value is being processed then we can't render values\n  // on the element at all therefore by setting the renderer to null then\n  // the styling apply code knows not to actually apply the values...\n  const renderer = tNode.type === TNodeType.Element ? lView[RENDERER] : null;\n  const isFirstRender = (lView[FLAGS] & LViewFlags.FirstLViewPass) !== 0;\n  const stylingContext = getStylingContext(index, lView);\n  const totalPlayersQueued = renderStyling(\n      stylingContext, renderer, lView, isFirstRender, null, null, directiveStylingIndex);\n  if (totalPlayersQueued > 0) {\n    const rootContext = getRootContext(lView);\n    scheduleTick(rootContext, RootContextFlags.FlushPlayers);\n  }\n\n  // because select(n) may not run between every instruction, the cached styling\n  // context may not get cleared between elements. The reason for this is because\n  // styling bindings (like `[style]` and `[class]`) are not recognized as property\n  // bindings by default so a select(n) instruction is not generated. To ensure the\n  // context is loaded correctly for the next element the cache below is pre-emptively\n  // cleared because there is no code in Angular that applies more styling code after a\n  // styling flush has occurred. Note that this will be fixed once FW-1254 lands.\n  setCachedStylingContext(null);\n}\n\nexport function getActiveDirectiveStylingIndex() {\n  // whenever a directive's hostBindings function is called a uniqueId value\n  // is assigned. Normally this is enough to help distinguish one directive\n  // from another for the styling context, but there are situations where a\n  // sub-class directive could inherit and assign styling in concert with a\n  // parent directive. To help the styling code distinguish between a parent\n  // sub-classed directive the inheritance depth is taken into account as well.\n  return getActiveDirectiveId() + getActiveDirectiveSuperClassDepth();\n}\n\nfunction getStylingContext(index: number, lView: LView) {\n  let context = getCachedStylingContext();\n  if (!context) {\n    context = getStylingContextFromLView(index + HEADER_OFFSET, lView);\n    setCachedStylingContext(context);\n  } else if (ngDevMode) {\n    const actualContext = getStylingContextFromLView(index + HEADER_OFFSET, lView);\n    assertEqual(context, actualContext, 'The cached styling context is invalid');\n  }\n  return context;\n}\n"]}
|
|
350
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"styling.js","sourceRoot":"","sources":["../../../../../../../../../../../packages/core/src/render3/instructions/styling.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 {StyleSanitizeFn} from '../../sanitization/style_sanitizer';\nimport {assertEqual} from '../../util/assert';\nimport {TNode, TNodeType} from '../interfaces/node';\nimport {PlayerFactory} from '../interfaces/player';\nimport {FLAGS, HEADER_OFFSET, LView, LViewFlags, RENDERER, RootContextFlags} from '../interfaces/view';\nimport {getActiveDirectiveId, getActiveDirectiveSuperClassDepth, getLView, getPreviousOrParentTNode, getSelectedIndex} from '../state';\nimport {getInitialClassNameValue, renderStyling, updateClassMap, updateClassProp as updateclassProp, updateContextWithBindings, updateStyleMap, updateStyleProp as updatestyleProp} from '../styling/class_and_style_bindings';\nimport {ParamsOf, enqueueHostInstruction, registerHostDirective} from '../styling/host_instructions_queue';\nimport {BoundPlayerFactory} from '../styling/player_factory';\nimport {DEFAULT_TEMPLATE_DIRECTIVE_INDEX} from '../styling/shared';\nimport {getCachedStylingContext, setCachedStylingContext} from '../styling/state';\nimport {allocateOrUpdateDirectiveIntoContext, createEmptyStylingContext, forceClassesAsString, forceStylesAsString, getStylingContextFromLView, hasClassInput, hasStyleInput} from '../styling/util';\nimport {classMap as newClassMap, classProp as newClassProp, styleMap as newStyleMap, styleProp as newStyleProp, stylingApply as newStylingApply, stylingInit as newStylingInit} from '../styling_next/instructions';\nimport {runtimeAllowOldStyling, runtimeIsNewStylingInUse} from '../styling_next/state';\nimport {getBindingNameFromIndex} from '../styling_next/util';\nimport {NO_CHANGE} from '../tokens';\nimport {renderStringify} from '../util/misc_utils';\nimport {getRootContext} from '../util/view_traversal_utils';\nimport {getTNode} from '../util/view_utils';\n\nimport {scheduleTick, setInputsForProperty} from './shared';\n\n\n\n/*\n * The contents of this file include the instructions for all styling-related\n * operations in Angular.\n *\n * The instructions present in this file are:\n *\n * Template level styling instructions:\n * - styling\n * - styleMap\n * - classMap\n * - styleProp\n * - classProp\n * - stylingApply\n */\n\n/**\n * Allocates style and class binding properties on the element during creation mode.\n *\n * This instruction is meant to be called during creation mode to register all\n * dynamic style and class bindings on the element. Note that this is only used\n * for binding values (see `elementStart` to learn how to assign static styling\n * values to an element).\n *\n * @param classBindingNames An array containing bindable class names.\n *        The `classProp` instruction refers to the class name by index in\n *        this array (i.e. `['foo', 'bar']` means `foo=0` and `bar=1`).\n * @param styleBindingNames An array containing bindable style properties.\n *        The `styleProp` instruction refers to the class name by index in\n *        this array (i.e. `['width', 'height']` means `width=0` and `height=1`).\n * @param styleSanitizer An optional sanitizer function that will be used to sanitize any CSS\n *        style values that are applied to the element (during rendering).\n *\n * Note that this will allocate the provided style/class bindings to the host element if\n * this function is called within a host binding.\n *\n * @codeGenApi\n */\nexport function ɵɵstyling(\n    classBindingNames?: string[] | null, styleBindingNames?: string[] | null,\n    styleSanitizer?: StyleSanitizeFn | null): void {\n  const tNode = getPreviousOrParentTNode();\n  if (!tNode.stylingTemplate) {\n    tNode.stylingTemplate = createEmptyStylingContext();\n  }\n\n  const directiveStylingIndex = getActiveDirectiveStylingIndex();\n  if (directiveStylingIndex) {\n    // this is temporary hack to get the existing styling instructions to\n    // play ball with the new refactored implementation.\n    // TODO (matsko): remove this once the old implementation is not needed.\n    if (runtimeIsNewStylingInUse()) {\n      newStylingInit();\n    }\n\n    // despite the binding being applied in a queue (below), the allocation\n    // of the directive into the context happens right away. The reason for\n    // this is to retain the ordering of the directives (which is important\n    // for the prioritization of bindings).\n    allocateOrUpdateDirectiveIntoContext(tNode.stylingTemplate, directiveStylingIndex);\n\n    const fns = tNode.onElementCreationFns = tNode.onElementCreationFns || [];\n    fns.push(() => {\n      initStyling(\n          tNode, classBindingNames, styleBindingNames, styleSanitizer, directiveStylingIndex);\n      registerHostDirective(tNode.stylingTemplate !, directiveStylingIndex);\n    });\n  } else {\n    // calling the function below ensures that the template's binding values\n    // are applied as the first set of bindings into the context. If any other\n    // styling bindings are set on the same element (by directives and/or\n    // components) then they will be applied at the end of the `elementEnd`\n    // instruction (because directives are created first before styling is\n    // executed for a new element).\n    initStyling(\n        tNode, classBindingNames, styleBindingNames, styleSanitizer,\n        DEFAULT_TEMPLATE_DIRECTIVE_INDEX);\n  }\n}\n\nfunction initStyling(\n    tNode: TNode, classBindingNames: string[] | null | undefined,\n    styleBindingNames: string[] | null | undefined,\n    styleSanitizer: StyleSanitizeFn | null | undefined, directiveStylingIndex: number): void {\n  updateContextWithBindings(\n      tNode.stylingTemplate !, directiveStylingIndex, classBindingNames, styleBindingNames,\n      styleSanitizer);\n}\n\n\n/**\n * Update a style binding on an element with the provided value.\n *\n * If the style value is falsy then it will be removed from the element\n * (or assigned a different value depending if there are any styles placed\n * on the element with `styleMap` or any static styles that are\n * present from when the element was created with `styling`).\n *\n * Note that the styling element is updated as part of `stylingApply`.\n *\n * @param styleIndex Index of style to update. This index value refers to the\n *        index of the style in the style bindings array that was passed into\n *        `styling`.\n * @param value New value to write (falsy to remove).\n * @param suffix Optional suffix. Used with scalar values to add unit such as `px`.\n *        Note that when a suffix is provided then the underlying sanitizer will\n *        be ignored.\n * @param forceOverride Whether or not to update the styling value immediately\n *        (despite the other bindings possibly having priority)\n *\n * Note that this will apply the provided style value to the host element if this function is called\n * within a host binding.\n *\n * @codeGenApi\n */\nexport function ɵɵstyleProp(\n    styleIndex: number, value: string | number | String | PlayerFactory | null,\n    suffix?: string | null, forceOverride?: boolean): void {\n  const index = getSelectedIndex();\n  const valueToAdd = resolveStylePropValue(value, suffix);\n  const stylingContext = getStylingContext(index, getLView());\n  const directiveStylingIndex = getActiveDirectiveStylingIndex();\n  if (directiveStylingIndex) {\n    const args: ParamsOf<typeof updatestyleProp> =\n        [stylingContext, styleIndex, valueToAdd, directiveStylingIndex, forceOverride];\n    enqueueHostInstruction(stylingContext, directiveStylingIndex, updatestyleProp, args);\n  } else {\n    updatestyleProp(\n        stylingContext, styleIndex, valueToAdd, DEFAULT_TEMPLATE_DIRECTIVE_INDEX, forceOverride);\n  }\n\n  if (runtimeIsNewStylingInUse()) {\n    const prop = getBindingNameFromIndex(stylingContext, styleIndex, directiveStylingIndex, false);\n\n    // the reason why we cast the value as `boolean` is\n    // because the new styling refactor does not yet support\n    // sanitization or animation players.\n    newStyleProp(prop, value as string | number, suffix);\n  }\n}\n\nfunction resolveStylePropValue(\n    value: string | number | String | PlayerFactory | null, suffix: string | null | undefined) {\n  let valueToAdd: string|null = null;\n  if (value !== null) {\n    if (suffix) {\n      // when a suffix is applied then it will bypass\n      // sanitization entirely (b/c a new string is created)\n      valueToAdd = renderStringify(value) + suffix;\n    } else {\n      // sanitization happens by dealing with a String value\n      // this means that the string value will be passed through\n      // into the style rendering later (which is where the value\n      // will be sanitized before it is applied)\n      valueToAdd = value as any as string;\n    }\n  }\n  return valueToAdd;\n}\n\n\n/**\n * Update a class binding on an element with the provided value.\n *\n * This instruction is meant to handle the `[class.foo]=\"exp\"` case and,\n * therefore, the class binding itself must already be allocated using\n * `styling` within the creation block.\n *\n * @param classIndex Index of class to toggle. This index value refers to the\n *        index of the class in the class bindings array that was passed into\n *        `styling` (which is meant to be called before this\n *        function is).\n * @param value A true/false value which will turn the class on or off.\n * @param forceOverride Whether or not this value will be applied regardless\n *        of where it is being set within the styling priority structure.\n *\n * Note that this will apply the provided class value to the host element if this function\n * is called within a host binding.\n *\n * @codeGenApi\n */\nexport function ɵɵclassProp(\n    classIndex: number, value: boolean | PlayerFactory, forceOverride?: boolean): void {\n  const index = getSelectedIndex();\n  const input = (value instanceof BoundPlayerFactory) ?\n      (value as BoundPlayerFactory<boolean|null>) :\n      booleanOrNull(value);\n  const directiveStylingIndex = getActiveDirectiveStylingIndex();\n  const stylingContext = getStylingContext(index, getLView());\n  if (directiveStylingIndex) {\n    const args: ParamsOf<typeof updateclassProp> =\n        [stylingContext, classIndex, input, directiveStylingIndex, forceOverride];\n    enqueueHostInstruction(stylingContext, directiveStylingIndex, updateclassProp, args);\n  } else {\n    updateclassProp(\n        stylingContext, classIndex, input, DEFAULT_TEMPLATE_DIRECTIVE_INDEX, forceOverride);\n  }\n\n  if (runtimeIsNewStylingInUse()) {\n    const prop = getBindingNameFromIndex(stylingContext, classIndex, directiveStylingIndex, true);\n\n    // the reason why we cast the value as `boolean` is\n    // because the new styling refactor does not yet support\n    // sanitization or animation players.\n    newClassProp(prop, input as boolean);\n  }\n}\n\n\nfunction booleanOrNull(value: any): boolean|null {\n  if (typeof value === 'boolean') return value;\n  return value ? true : null;\n}\n\n\n/**\n * Update style bindings using an object literal on an element.\n *\n * This instruction is meant to apply styling via the `[style]=\"exp\"` template bindings.\n * When styles are applied to the element they will then be updated with respect to\n * any styles/classes set via `styleProp`. If any styles are set to falsy\n * then they will be removed from the element.\n *\n * Note that the styling instruction will not be applied until `stylingApply` is called.\n *\n * @param styles A key/value style map of the styles that will be applied to the given element.\n *        Any missing styles (that have already been applied to the element beforehand) will be\n *        removed (unset) from the element's styling.\n *\n * Note that this will apply the provided styleMap value to the host element if this function\n * is called within a host binding.\n *\n * @codeGenApi\n */\nexport function ɵɵstyleMap(styles: {[styleName: string]: any} | NO_CHANGE | null): void {\n  const index = getSelectedIndex();\n  const lView = getLView();\n  const stylingContext = getStylingContext(index, lView);\n  const directiveStylingIndex = getActiveDirectiveStylingIndex();\n  if (directiveStylingIndex) {\n    const args: ParamsOf<typeof updateStyleMap> = [stylingContext, styles, directiveStylingIndex];\n    enqueueHostInstruction(stylingContext, directiveStylingIndex, updateStyleMap, args);\n  } else {\n    const tNode = getTNode(index, lView);\n\n    // inputs are only evaluated from a template binding into a directive, therefore,\n    // there should not be a situation where a directive host bindings function\n    // evaluates the inputs (this should only happen in the template function)\n    if (hasStyleInput(tNode) && styles !== NO_CHANGE) {\n      const initialStyles = getInitialClassNameValue(stylingContext);\n      const styleInputVal =\n          (initialStyles.length ? (initialStyles + ' ') : '') + forceStylesAsString(styles);\n      setInputsForProperty(lView, tNode.inputs !['style'] !, styleInputVal);\n      styles = NO_CHANGE;\n    }\n    updateStyleMap(stylingContext, styles);\n  }\n\n  if (runtimeIsNewStylingInUse()) {\n    newStyleMap(styles);\n  }\n}\n\n\n/**\n * Update class bindings using an object literal or class-string on an element.\n *\n * This instruction is meant to apply styling via the `[class]=\"exp\"` template bindings.\n * When classes are applied to the element they will then be updated with\n * respect to any styles/classes set via `classProp`. If any\n * classes are set to falsy then they will be removed from the element.\n *\n * Note that the styling instruction will not be applied until `stylingApply` is called.\n * Note that this will the provided classMap value to the host element if this function is called\n * within a host binding.\n *\n * @param classes A key/value map or string of CSS classes that will be added to the\n *        given element. Any missing classes (that have already been applied to the element\n *        beforehand) will be removed (unset) from the element's list of CSS classes.\n *\n * @codeGenApi\n */\nexport function ɵɵclassMap(classes: {[styleName: string]: any} | NO_CHANGE | string | null): void {\n  const index = getSelectedIndex();\n  const lView = getLView();\n  const stylingContext = getStylingContext(index, lView);\n  const directiveStylingIndex = getActiveDirectiveStylingIndex();\n  if (directiveStylingIndex) {\n    const args: ParamsOf<typeof updateClassMap> = [stylingContext, classes, directiveStylingIndex];\n    enqueueHostInstruction(stylingContext, directiveStylingIndex, updateClassMap, args);\n  } else {\n    const tNode = getTNode(index, lView);\n    // inputs are only evaluated from a template binding into a directive, therefore,\n    // there should not be a situation where a directive host bindings function\n    // evaluates the inputs (this should only happen in the template function)\n    if (hasClassInput(tNode) && classes !== NO_CHANGE) {\n      const initialClasses = getInitialClassNameValue(stylingContext);\n      const classInputVal =\n          (initialClasses.length ? (initialClasses + ' ') : '') + forceClassesAsString(classes);\n      setInputsForProperty(lView, tNode.inputs !['class'] !, classInputVal);\n      classes = NO_CHANGE;\n    }\n    updateClassMap(stylingContext, classes);\n  }\n\n  if (runtimeIsNewStylingInUse()) {\n    newClassMap(classes);\n  }\n}\n\n/**\n * Apply all style and class binding values to the element.\n *\n * This instruction is meant to be run after `styleMap`, `classMap`,\n * `styleProp` or `classProp` instructions have been run and will\n * only apply styling to the element if any styling bindings have been updated.\n *\n * @codeGenApi\n */\nexport function ɵɵstylingApply(): void {\n  const index = getSelectedIndex();\n  const directiveStylingIndex =\n      getActiveDirectiveStylingIndex() || DEFAULT_TEMPLATE_DIRECTIVE_INDEX;\n  const lView = getLView();\n  const tNode = getTNode(index, lView);\n\n  // if a non-element value is being processed then we can't render values\n  // on the element at all therefore by setting the renderer to null then\n  // the styling apply code knows not to actually apply the values...\n  const renderer = tNode.type === TNodeType.Element ? lView[RENDERER] : null;\n  const isFirstRender = (lView[FLAGS] & LViewFlags.FirstLViewPass) !== 0;\n  const stylingContext = getStylingContext(index, lView);\n\n  if (runtimeAllowOldStyling()) {\n    const totalPlayersQueued = renderStyling(\n        stylingContext, renderer, lView, isFirstRender, null, null, directiveStylingIndex);\n    if (totalPlayersQueued > 0) {\n      const rootContext = getRootContext(lView);\n      scheduleTick(rootContext, RootContextFlags.FlushPlayers);\n    }\n  }\n\n  // because select(n) may not run between every instruction, the cached styling\n  // context may not get cleared between elements. The reason for this is because\n  // styling bindings (like `[style]` and `[class]`) are not recognized as property\n  // bindings by default so a select(n) instruction is not generated. To ensure the\n  // context is loaded correctly for the next element the cache below is pre-emptively\n  // cleared because there is no code in Angular that applies more styling code after a\n  // styling flush has occurred. Note that this will be fixed once FW-1254 lands.\n  setCachedStylingContext(null);\n\n  if (runtimeIsNewStylingInUse()) {\n    newStylingApply();\n  }\n}\n\nexport function getActiveDirectiveStylingIndex() {\n  // whenever a directive's hostBindings function is called a uniqueId value\n  // is assigned. Normally this is enough to help distinguish one directive\n  // from another for the styling context, but there are situations where a\n  // sub-class directive could inherit and assign styling in concert with a\n  // parent directive. To help the styling code distinguish between a parent\n  // sub-classed directive the inheritance depth is taken into account as well.\n  return getActiveDirectiveId() + getActiveDirectiveSuperClassDepth();\n}\n\nfunction getStylingContext(index: number, lView: LView) {\n  let context = getCachedStylingContext();\n  if (!context) {\n    context = getStylingContextFromLView(index + HEADER_OFFSET, lView);\n    setCachedStylingContext(context);\n  } else if (ngDevMode) {\n    const actualContext = getStylingContextFromLView(index + HEADER_OFFSET, lView);\n    assertEqual(context, actualContext, 'The cached styling context is invalid');\n  }\n  return context;\n}\n"]}
|