@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
|
@@ -5,12 +5,15 @@
|
|
|
5
5
|
import { assertEqual } from '../../util/assert';
|
|
6
6
|
import { FLAGS, HEADER_OFFSET, RENDERER } from '../interfaces/view';
|
|
7
7
|
import { getActiveDirectiveId, getActiveDirectiveSuperClassDepth, getLView, getPreviousOrParentTNode, getSelectedIndex } from '../state';
|
|
8
|
-
import { getInitialClassNameValue, renderStyling, updateClassProp as
|
|
8
|
+
import { getInitialClassNameValue, renderStyling, updateClassMap, updateClassProp as updateclassProp, updateContextWithBindings, updateStyleMap, updateStyleProp as updatestyleProp } from '../styling/class_and_style_bindings';
|
|
9
9
|
import { enqueueHostInstruction, registerHostDirective } from '../styling/host_instructions_queue';
|
|
10
10
|
import { BoundPlayerFactory } from '../styling/player_factory';
|
|
11
11
|
import { DEFAULT_TEMPLATE_DIRECTIVE_INDEX } from '../styling/shared';
|
|
12
12
|
import { getCachedStylingContext, setCachedStylingContext } from '../styling/state';
|
|
13
13
|
import { allocateOrUpdateDirectiveIntoContext, createEmptyStylingContext, forceClassesAsString, forceStylesAsString, getStylingContextFromLView, hasClassInput, hasStyleInput } from '../styling/util';
|
|
14
|
+
import { classMap as newClassMap, classProp as newClassProp, styleMap as newStyleMap, styleProp as newStyleProp, stylingApply as newStylingApply, stylingInit as newStylingInit } from '../styling_next/instructions';
|
|
15
|
+
import { runtimeAllowOldStyling, runtimeIsNewStylingInUse } from '../styling_next/state';
|
|
16
|
+
import { getBindingNameFromIndex } from '../styling_next/util';
|
|
14
17
|
import { NO_CHANGE } from '../tokens';
|
|
15
18
|
import { renderStringify } from '../util/misc_utils';
|
|
16
19
|
import { getRootContext } from '../util/view_traversal_utils';
|
|
@@ -23,18 +26,12 @@ import { scheduleTick, setInputsForProperty } from './shared';
|
|
|
23
26
|
* The instructions present in this file are:
|
|
24
27
|
*
|
|
25
28
|
* Template level styling instructions:
|
|
26
|
-
* -
|
|
27
|
-
* -
|
|
28
|
-
* -
|
|
29
|
-
* -
|
|
30
|
-
* -
|
|
31
|
-
*
|
|
32
|
-
* Host bindings level styling instructions:
|
|
33
|
-
* - elementHostStyling
|
|
34
|
-
* - elementHostStylingMap
|
|
35
|
-
* - elementHostStyleProp
|
|
36
|
-
* - elementHostClassProp
|
|
37
|
-
* - elementHostStylingApply
|
|
29
|
+
* - styling
|
|
30
|
+
* - styleMap
|
|
31
|
+
* - classMap
|
|
32
|
+
* - styleProp
|
|
33
|
+
* - classProp
|
|
34
|
+
* - stylingApply
|
|
38
35
|
*/
|
|
39
36
|
/**
|
|
40
37
|
* Allocates style and class binding properties on the element during creation mode.
|
|
@@ -46,55 +43,20 @@ import { scheduleTick, setInputsForProperty } from './shared';
|
|
|
46
43
|
*
|
|
47
44
|
* \@codeGenApi
|
|
48
45
|
* @param {?=} classBindingNames An array containing bindable class names.
|
|
49
|
-
* The `
|
|
46
|
+
* The `classProp` instruction refers to the class name by index in
|
|
50
47
|
* this array (i.e. `['foo', 'bar']` means `foo=0` and `bar=1`).
|
|
51
48
|
* @param {?=} styleBindingNames An array containing bindable style properties.
|
|
52
|
-
* The `
|
|
49
|
+
* The `styleProp` instruction refers to the class name by index in
|
|
53
50
|
* this array (i.e. `['width', 'height']` means `width=0` and `height=1`).
|
|
54
51
|
* @param {?=} styleSanitizer An optional sanitizer function that will be used to sanitize any CSS
|
|
55
52
|
* style values that are applied to the element (during rendering).
|
|
56
53
|
*
|
|
57
|
-
*
|
|
58
|
-
|
|
59
|
-
export function ɵɵelementStyling(classBindingNames, styleBindingNames, styleSanitizer) {
|
|
60
|
-
/** @type {?} */
|
|
61
|
-
const tNode = getPreviousOrParentTNode();
|
|
62
|
-
if (!tNode.stylingTemplate) {
|
|
63
|
-
tNode.stylingTemplate = createEmptyStylingContext();
|
|
64
|
-
}
|
|
65
|
-
// calling the function below ensures that the template's binding values
|
|
66
|
-
// are applied as the first set of bindings into the context. If any other
|
|
67
|
-
// styling bindings are set on the same element (by directives and/or
|
|
68
|
-
// components) then they will be applied at the end of the `elementEnd`
|
|
69
|
-
// instruction (because directives are created first before styling is
|
|
70
|
-
// executed for a new element).
|
|
71
|
-
initElementStyling(tNode, classBindingNames, styleBindingNames, styleSanitizer, DEFAULT_TEMPLATE_DIRECTIVE_INDEX);
|
|
72
|
-
}
|
|
73
|
-
/**
|
|
74
|
-
* Allocates style and class binding properties on the host element during creation mode
|
|
75
|
-
* within the host bindings function of a directive or component.
|
|
76
|
-
*
|
|
77
|
-
* This instruction is meant to be called during creation mode to register all
|
|
78
|
-
* dynamic style and class host bindings on the host element of a directive or
|
|
79
|
-
* component. Note that this is only used for binding values (see `elementHostAttrs`
|
|
80
|
-
* to learn how to assign static styling values to the host element).
|
|
81
|
-
*
|
|
82
|
-
* \@codeGenApi
|
|
83
|
-
* @param {?=} classBindingNames An array containing bindable class names.
|
|
84
|
-
* The `elementHostClassProp` instruction refers to the class name by index in
|
|
85
|
-
* this array (i.e. `['foo', 'bar']` means `foo=0` and `bar=1`).
|
|
86
|
-
* @param {?=} styleBindingNames An array containing bindable style properties.
|
|
87
|
-
* The `elementHostStyleProp` instruction refers to the class name by index in
|
|
88
|
-
* this array (i.e. `['width', 'height']` means `width=0` and `height=1`).
|
|
89
|
-
* @param {?=} styleSanitizer An optional sanitizer function that will be used to sanitize any CSS
|
|
90
|
-
* style values that are applied to the element (during rendering).
|
|
91
|
-
* Note that the sanitizer instance itself is tied to the provided `directive` and
|
|
92
|
-
* will not be used if the same property is assigned in another directive or
|
|
93
|
-
* on the element directly.
|
|
54
|
+
* Note that this will allocate the provided style/class bindings to the host element if
|
|
55
|
+
* this function is called within a host binding.
|
|
94
56
|
*
|
|
95
57
|
* @return {?}
|
|
96
58
|
*/
|
|
97
|
-
export function
|
|
59
|
+
export function ɵɵstyling(classBindingNames, styleBindingNames, styleSanitizer) {
|
|
98
60
|
/** @type {?} */
|
|
99
61
|
const tNode = getPreviousOrParentTNode();
|
|
100
62
|
if (!tNode.stylingTemplate) {
|
|
@@ -102,20 +64,37 @@ export function ɵɵelementHostStyling(classBindingNames, styleBindingNames, sty
|
|
|
102
64
|
}
|
|
103
65
|
/** @type {?} */
|
|
104
66
|
const directiveStylingIndex = getActiveDirectiveStylingIndex();
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
67
|
+
if (directiveStylingIndex) {
|
|
68
|
+
// this is temporary hack to get the existing styling instructions to
|
|
69
|
+
// play ball with the new refactored implementation.
|
|
70
|
+
// TODO (matsko): remove this once the old implementation is not needed.
|
|
71
|
+
if (runtimeIsNewStylingInUse()) {
|
|
72
|
+
newStylingInit();
|
|
73
|
+
}
|
|
74
|
+
// despite the binding being applied in a queue (below), the allocation
|
|
75
|
+
// of the directive into the context happens right away. The reason for
|
|
76
|
+
// this is to retain the ordering of the directives (which is important
|
|
77
|
+
// for the prioritization of bindings).
|
|
78
|
+
allocateOrUpdateDirectiveIntoContext(tNode.stylingTemplate, directiveStylingIndex);
|
|
79
|
+
/** @type {?} */
|
|
80
|
+
const fns = tNode.onElementCreationFns = tNode.onElementCreationFns || [];
|
|
81
|
+
fns.push((/**
|
|
82
|
+
* @return {?}
|
|
83
|
+
*/
|
|
84
|
+
() => {
|
|
85
|
+
initStyling(tNode, classBindingNames, styleBindingNames, styleSanitizer, directiveStylingIndex);
|
|
86
|
+
registerHostDirective((/** @type {?} */ (tNode.stylingTemplate)), directiveStylingIndex);
|
|
87
|
+
}));
|
|
88
|
+
}
|
|
89
|
+
else {
|
|
90
|
+
// calling the function below ensures that the template's binding values
|
|
91
|
+
// are applied as the first set of bindings into the context. If any other
|
|
92
|
+
// styling bindings are set on the same element (by directives and/or
|
|
93
|
+
// components) then they will be applied at the end of the `elementEnd`
|
|
94
|
+
// instruction (because directives are created first before styling is
|
|
95
|
+
// executed for a new element).
|
|
96
|
+
initStyling(tNode, classBindingNames, styleBindingNames, styleSanitizer, DEFAULT_TEMPLATE_DIRECTIVE_INDEX);
|
|
97
|
+
}
|
|
119
98
|
}
|
|
120
99
|
/**
|
|
121
100
|
* @param {?} tNode
|
|
@@ -125,7 +104,7 @@ export function ɵɵelementHostStyling(classBindingNames, styleBindingNames, sty
|
|
|
125
104
|
* @param {?} directiveStylingIndex
|
|
126
105
|
* @return {?}
|
|
127
106
|
*/
|
|
128
|
-
function
|
|
107
|
+
function initStyling(tNode, classBindingNames, styleBindingNames, styleSanitizer, directiveStylingIndex) {
|
|
129
108
|
updateContextWithBindings((/** @type {?} */ (tNode.stylingTemplate)), directiveStylingIndex, classBindingNames, styleBindingNames, styleSanitizer);
|
|
130
109
|
}
|
|
131
110
|
/**
|
|
@@ -133,73 +112,52 @@ function initElementStyling(tNode, classBindingNames, styleBindingNames, styleSa
|
|
|
133
112
|
*
|
|
134
113
|
* If the style value is falsy then it will be removed from the element
|
|
135
114
|
* (or assigned a different value depending if there are any styles placed
|
|
136
|
-
* on the element with `
|
|
137
|
-
* present from when the element was created with `
|
|
115
|
+
* on the element with `styleMap` or any static styles that are
|
|
116
|
+
* present from when the element was created with `styling`).
|
|
138
117
|
*
|
|
139
|
-
* Note that the styling element is updated as part of `
|
|
118
|
+
* Note that the styling element is updated as part of `stylingApply`.
|
|
140
119
|
*
|
|
141
120
|
* \@codeGenApi
|
|
142
|
-
* @param {?} index Index of the element's with which styling is associated.
|
|
143
121
|
* @param {?} styleIndex Index of style to update. This index value refers to the
|
|
144
122
|
* index of the style in the style bindings array that was passed into
|
|
145
|
-
* `
|
|
146
|
-
* @param {?} value New value to write (falsy to remove).
|
|
147
|
-
* attempts to write to the same binding value (via `elementHostStyleProp`)
|
|
148
|
-
* then it will only be able to do so if the binding value assigned via
|
|
149
|
-
* `elementStyleProp` is falsy (or doesn't exist at all).
|
|
123
|
+
* `styling`.
|
|
124
|
+
* @param {?} value New value to write (falsy to remove).
|
|
150
125
|
* @param {?=} suffix Optional suffix. Used with scalar values to add unit such as `px`.
|
|
151
126
|
* Note that when a suffix is provided then the underlying sanitizer will
|
|
152
127
|
* be ignored.
|
|
153
128
|
* @param {?=} forceOverride Whether or not to update the styling value immediately
|
|
154
129
|
* (despite the other bindings possibly having priority)
|
|
155
130
|
*
|
|
131
|
+
* Note that this will apply the provided style value to the host element if this function is called
|
|
132
|
+
* within a host binding.
|
|
133
|
+
*
|
|
156
134
|
* @return {?}
|
|
157
135
|
*/
|
|
158
|
-
export function
|
|
136
|
+
export function ɵɵstyleProp(styleIndex, value, suffix, forceOverride) {
|
|
137
|
+
/** @type {?} */
|
|
138
|
+
const index = getSelectedIndex();
|
|
159
139
|
/** @type {?} */
|
|
160
140
|
const valueToAdd = resolveStylePropValue(value, suffix);
|
|
161
141
|
/** @type {?} */
|
|
162
142
|
const stylingContext = getStylingContext(index, getLView());
|
|
163
|
-
updateElementStyleProp(stylingContext, styleIndex, valueToAdd, DEFAULT_TEMPLATE_DIRECTIVE_INDEX, forceOverride);
|
|
164
|
-
}
|
|
165
|
-
/**
|
|
166
|
-
* Update a host style binding value on the host element within a component/directive.
|
|
167
|
-
*
|
|
168
|
-
* If the style value is falsy then it will be removed from the host element
|
|
169
|
-
* (or assigned a different value depending if there are any styles placed
|
|
170
|
-
* on the same element with `elementHostStylingMap` or any static styles that
|
|
171
|
-
* are present from when the element was patched with `elementHostStyling`).
|
|
172
|
-
*
|
|
173
|
-
* Note that the styling applied to the host element once
|
|
174
|
-
* `elementHostStylingApply` is called.
|
|
175
|
-
*
|
|
176
|
-
* \@codeGenApi
|
|
177
|
-
* @param {?} styleIndex Index of style to update. This index value refers to the
|
|
178
|
-
* index of the style in the style bindings array that was passed into
|
|
179
|
-
* `elementHostStyling`.
|
|
180
|
-
* @param {?} value New value to write (falsy to remove). The value may or may not
|
|
181
|
-
* be applied to the element depending on the template/component/directive
|
|
182
|
-
* prioritization (see `interfaces/styling.ts`)
|
|
183
|
-
* @param {?=} suffix Optional suffix. Used with scalar values to add unit such as `px`.
|
|
184
|
-
* Note that when a suffix is provided then the underlying sanitizer will
|
|
185
|
-
* be ignored.
|
|
186
|
-
* @param {?=} forceOverride Whether or not to update the styling value immediately
|
|
187
|
-
* (despite the other bindings possibly having priority)
|
|
188
|
-
*
|
|
189
|
-
* @return {?}
|
|
190
|
-
*/
|
|
191
|
-
export function ɵɵelementHostStyleProp(styleIndex, value, suffix, forceOverride) {
|
|
192
143
|
/** @type {?} */
|
|
193
144
|
const directiveStylingIndex = getActiveDirectiveStylingIndex();
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
145
|
+
if (directiveStylingIndex) {
|
|
146
|
+
/** @type {?} */
|
|
147
|
+
const args = [stylingContext, styleIndex, valueToAdd, directiveStylingIndex, forceOverride];
|
|
148
|
+
enqueueHostInstruction(stylingContext, directiveStylingIndex, updatestyleProp, args);
|
|
149
|
+
}
|
|
150
|
+
else {
|
|
151
|
+
updatestyleProp(stylingContext, styleIndex, valueToAdd, DEFAULT_TEMPLATE_DIRECTIVE_INDEX, forceOverride);
|
|
152
|
+
}
|
|
153
|
+
if (runtimeIsNewStylingInUse()) {
|
|
154
|
+
/** @type {?} */
|
|
155
|
+
const prop = getBindingNameFromIndex(stylingContext, styleIndex, directiveStylingIndex, false);
|
|
156
|
+
// the reason why we cast the value as `boolean` is
|
|
157
|
+
// because the new styling refactor does not yet support
|
|
158
|
+
// sanitization or animation players.
|
|
159
|
+
newStyleProp(prop, (/** @type {?} */ (value)), suffix);
|
|
160
|
+
}
|
|
203
161
|
}
|
|
204
162
|
/**
|
|
205
163
|
* @param {?} value
|
|
@@ -230,62 +188,49 @@ function resolveStylePropValue(value, suffix) {
|
|
|
230
188
|
*
|
|
231
189
|
* This instruction is meant to handle the `[class.foo]="exp"` case and,
|
|
232
190
|
* therefore, the class binding itself must already be allocated using
|
|
233
|
-
* `
|
|
191
|
+
* `styling` within the creation block.
|
|
234
192
|
*
|
|
235
193
|
* \@codeGenApi
|
|
236
|
-
* @param {?} index Index of the element's with which styling is associated.
|
|
237
194
|
* @param {?} classIndex Index of class to toggle. This index value refers to the
|
|
238
195
|
* index of the class in the class bindings array that was passed into
|
|
239
|
-
* `
|
|
196
|
+
* `styling` (which is meant to be called before this
|
|
240
197
|
* function is).
|
|
241
198
|
* @param {?} value A true/false value which will turn the class on or off.
|
|
242
199
|
* @param {?=} forceOverride Whether or not this value will be applied regardless
|
|
243
200
|
* of where it is being set within the styling priority structure.
|
|
244
201
|
*
|
|
245
|
-
*
|
|
246
|
-
|
|
247
|
-
export function ɵɵelementClassProp(index, classIndex, value, forceOverride) {
|
|
248
|
-
/** @type {?} */
|
|
249
|
-
const input = (value instanceof BoundPlayerFactory) ?
|
|
250
|
-
((/** @type {?} */ (value))) :
|
|
251
|
-
booleanOrNull(value);
|
|
252
|
-
/** @type {?} */
|
|
253
|
-
const stylingContext = getStylingContext(index, getLView());
|
|
254
|
-
updateElementClassProp(stylingContext, classIndex, input, DEFAULT_TEMPLATE_DIRECTIVE_INDEX, forceOverride);
|
|
255
|
-
}
|
|
256
|
-
/**
|
|
257
|
-
* Update a class host binding for a directive's/component's host element within
|
|
258
|
-
* the host bindings function.
|
|
259
|
-
*
|
|
260
|
-
* This instruction is meant to handle the `\@HostBinding('class.foo')` case and,
|
|
261
|
-
* therefore, the class binding itself must already be allocated using
|
|
262
|
-
* `elementHostStyling` within the creation block.
|
|
263
|
-
*
|
|
264
|
-
* \@codeGenApi
|
|
265
|
-
* @param {?} classIndex Index of class to toggle. This index value refers to the
|
|
266
|
-
* index of the class in the class bindings array that was passed into
|
|
267
|
-
* `elementHostStlying` (which is meant to be called before this
|
|
268
|
-
* function is).
|
|
269
|
-
* @param {?} value A true/false value which will turn the class on or off.
|
|
270
|
-
* @param {?=} forceOverride Whether or not this value will be applied regardless
|
|
271
|
-
* of where it is being set within the stylings priority structure.
|
|
202
|
+
* Note that this will apply the provided class value to the host element if this function
|
|
203
|
+
* is called within a host binding.
|
|
272
204
|
*
|
|
273
205
|
* @return {?}
|
|
274
206
|
*/
|
|
275
|
-
export function
|
|
276
|
-
/** @type {?} */
|
|
277
|
-
const directiveStylingIndex = getActiveDirectiveStylingIndex();
|
|
207
|
+
export function ɵɵclassProp(classIndex, value, forceOverride) {
|
|
278
208
|
/** @type {?} */
|
|
279
|
-
const
|
|
280
|
-
/** @type {?} */
|
|
281
|
-
const stylingContext = getStylingContext(hostElementIndex, getLView());
|
|
209
|
+
const index = getSelectedIndex();
|
|
282
210
|
/** @type {?} */
|
|
283
211
|
const input = (value instanceof BoundPlayerFactory) ?
|
|
284
212
|
((/** @type {?} */ (value))) :
|
|
285
213
|
booleanOrNull(value);
|
|
286
214
|
/** @type {?} */
|
|
287
|
-
const
|
|
288
|
-
|
|
215
|
+
const directiveStylingIndex = getActiveDirectiveStylingIndex();
|
|
216
|
+
/** @type {?} */
|
|
217
|
+
const stylingContext = getStylingContext(index, getLView());
|
|
218
|
+
if (directiveStylingIndex) {
|
|
219
|
+
/** @type {?} */
|
|
220
|
+
const args = [stylingContext, classIndex, input, directiveStylingIndex, forceOverride];
|
|
221
|
+
enqueueHostInstruction(stylingContext, directiveStylingIndex, updateclassProp, args);
|
|
222
|
+
}
|
|
223
|
+
else {
|
|
224
|
+
updateclassProp(stylingContext, classIndex, input, DEFAULT_TEMPLATE_DIRECTIVE_INDEX, forceOverride);
|
|
225
|
+
}
|
|
226
|
+
if (runtimeIsNewStylingInUse()) {
|
|
227
|
+
/** @type {?} */
|
|
228
|
+
const prop = getBindingNameFromIndex(stylingContext, classIndex, directiveStylingIndex, true);
|
|
229
|
+
// the reason why we cast the value as `boolean` is
|
|
230
|
+
// because the new styling refactor does not yet support
|
|
231
|
+
// sanitization or animation players.
|
|
232
|
+
newClassProp(prop, (/** @type {?} */ (input)));
|
|
233
|
+
}
|
|
289
234
|
}
|
|
290
235
|
/**
|
|
291
236
|
* @param {?} value
|
|
@@ -297,124 +242,127 @@ function booleanOrNull(value) {
|
|
|
297
242
|
return value ? true : null;
|
|
298
243
|
}
|
|
299
244
|
/**
|
|
300
|
-
* Update style
|
|
245
|
+
* Update style bindings using an object literal on an element.
|
|
301
246
|
*
|
|
302
|
-
* This instruction is meant to apply styling via the `[style]="exp"`
|
|
303
|
-
*
|
|
304
|
-
*
|
|
305
|
-
*
|
|
247
|
+
* This instruction is meant to apply styling via the `[style]="exp"` template bindings.
|
|
248
|
+
* When styles are applied to the element they will then be updated with respect to
|
|
249
|
+
* any styles/classes set via `styleProp`. If any styles are set to falsy
|
|
250
|
+
* then they will be removed from the element.
|
|
306
251
|
*
|
|
307
|
-
* Note that the styling instruction will not be applied until `
|
|
252
|
+
* Note that the styling instruction will not be applied until `stylingApply` is called.
|
|
308
253
|
*
|
|
309
254
|
* \@codeGenApi
|
|
310
|
-
* @param {?}
|
|
311
|
-
* @param {?} classes A key/value map or string of CSS classes that will be added to the
|
|
312
|
-
* given element. Any missing classes (that have already been applied to the element
|
|
313
|
-
* beforehand) will be removed (unset) from the element's list of CSS classes.
|
|
314
|
-
* @param {?=} styles A key/value style map of the styles that will be applied to the given element.
|
|
255
|
+
* @param {?} styles A key/value style map of the styles that will be applied to the given element.
|
|
315
256
|
* Any missing styles (that have already been applied to the element beforehand) will be
|
|
316
257
|
* removed (unset) from the element's styling.
|
|
317
258
|
*
|
|
259
|
+
* Note that this will apply the provided styleMap value to the host element if this function
|
|
260
|
+
* is called within a host binding.
|
|
261
|
+
*
|
|
318
262
|
* @return {?}
|
|
319
263
|
*/
|
|
320
|
-
export function
|
|
264
|
+
export function ɵɵstyleMap(styles) {
|
|
265
|
+
/** @type {?} */
|
|
266
|
+
const index = getSelectedIndex();
|
|
321
267
|
/** @type {?} */
|
|
322
268
|
const lView = getLView();
|
|
323
269
|
/** @type {?} */
|
|
324
270
|
const stylingContext = getStylingContext(index, lView);
|
|
325
271
|
/** @type {?} */
|
|
326
|
-
const
|
|
327
|
-
|
|
328
|
-
// there should not be a situation where a directive host bindings function
|
|
329
|
-
// evaluates the inputs (this should only happen in the template function)
|
|
330
|
-
if (hasClassInput(tNode) && classes !== NO_CHANGE) {
|
|
331
|
-
/** @type {?} */
|
|
332
|
-
const initialClasses = getInitialClassNameValue(stylingContext);
|
|
272
|
+
const directiveStylingIndex = getActiveDirectiveStylingIndex();
|
|
273
|
+
if (directiveStylingIndex) {
|
|
333
274
|
/** @type {?} */
|
|
334
|
-
const
|
|
335
|
-
|
|
336
|
-
classes = NO_CHANGE;
|
|
275
|
+
const args = [stylingContext, styles, directiveStylingIndex];
|
|
276
|
+
enqueueHostInstruction(stylingContext, directiveStylingIndex, updateStyleMap, args);
|
|
337
277
|
}
|
|
338
|
-
|
|
339
|
-
/** @type {?} */
|
|
340
|
-
const initialStyles = getInitialClassNameValue(stylingContext);
|
|
278
|
+
else {
|
|
341
279
|
/** @type {?} */
|
|
342
|
-
const
|
|
343
|
-
|
|
344
|
-
|
|
280
|
+
const tNode = getTNode(index, lView);
|
|
281
|
+
// inputs are only evaluated from a template binding into a directive, therefore,
|
|
282
|
+
// there should not be a situation where a directive host bindings function
|
|
283
|
+
// evaluates the inputs (this should only happen in the template function)
|
|
284
|
+
if (hasStyleInput(tNode) && styles !== NO_CHANGE) {
|
|
285
|
+
/** @type {?} */
|
|
286
|
+
const initialStyles = getInitialClassNameValue(stylingContext);
|
|
287
|
+
/** @type {?} */
|
|
288
|
+
const styleInputVal = (initialStyles.length ? (initialStyles + ' ') : '') + forceStylesAsString(styles);
|
|
289
|
+
setInputsForProperty(lView, (/** @type {?} */ ((/** @type {?} */ (tNode.inputs))['style'])), styleInputVal);
|
|
290
|
+
styles = NO_CHANGE;
|
|
291
|
+
}
|
|
292
|
+
updateStyleMap(stylingContext, styles);
|
|
293
|
+
}
|
|
294
|
+
if (runtimeIsNewStylingInUse()) {
|
|
295
|
+
newStyleMap(styles);
|
|
345
296
|
}
|
|
346
|
-
updateStylingMap(stylingContext, classes, styles);
|
|
347
297
|
}
|
|
348
298
|
/**
|
|
349
|
-
* Update
|
|
350
|
-
* bindings function for a directive/component.
|
|
299
|
+
* Update class bindings using an object literal or class-string on an element.
|
|
351
300
|
*
|
|
352
|
-
* This instruction is meant to apply styling via the
|
|
353
|
-
*
|
|
354
|
-
*
|
|
355
|
-
*
|
|
356
|
-
* `elementHostClassProp`. If any styles or classes are set to falsy then they
|
|
357
|
-
* will be removed from the element.
|
|
301
|
+
* This instruction is meant to apply styling via the `[class]="exp"` template bindings.
|
|
302
|
+
* When classes are applied to the element they will then be updated with
|
|
303
|
+
* respect to any styles/classes set via `classProp`. If any
|
|
304
|
+
* classes are set to falsy then they will be removed from the element.
|
|
358
305
|
*
|
|
359
|
-
* Note that the styling instruction will not be applied until
|
|
360
|
-
*
|
|
306
|
+
* Note that the styling instruction will not be applied until `stylingApply` is called.
|
|
307
|
+
* Note that this will the provided classMap value to the host element if this function is called
|
|
308
|
+
* within a host binding.
|
|
361
309
|
*
|
|
362
310
|
* \@codeGenApi
|
|
363
311
|
* @param {?} classes A key/value map or string of CSS classes that will be added to the
|
|
364
312
|
* given element. Any missing classes (that have already been applied to the element
|
|
365
313
|
* beforehand) will be removed (unset) from the element's list of CSS classes.
|
|
366
|
-
* @param {?=} styles A key/value style map of the styles that will be applied to the given element.
|
|
367
|
-
* Any missing styles (that have already been applied to the element beforehand) will be
|
|
368
|
-
* removed (unset) from the element's styling.
|
|
369
314
|
*
|
|
370
315
|
* @return {?}
|
|
371
316
|
*/
|
|
372
|
-
export function
|
|
317
|
+
export function ɵɵclassMap(classes) {
|
|
373
318
|
/** @type {?} */
|
|
374
|
-
const
|
|
319
|
+
const index = getSelectedIndex();
|
|
375
320
|
/** @type {?} */
|
|
376
|
-
const
|
|
321
|
+
const lView = getLView();
|
|
377
322
|
/** @type {?} */
|
|
378
|
-
const stylingContext = getStylingContext(
|
|
323
|
+
const stylingContext = getStylingContext(index, lView);
|
|
379
324
|
/** @type {?} */
|
|
380
|
-
const
|
|
381
|
-
|
|
325
|
+
const directiveStylingIndex = getActiveDirectiveStylingIndex();
|
|
326
|
+
if (directiveStylingIndex) {
|
|
327
|
+
/** @type {?} */
|
|
328
|
+
const args = [stylingContext, classes, directiveStylingIndex];
|
|
329
|
+
enqueueHostInstruction(stylingContext, directiveStylingIndex, updateClassMap, args);
|
|
330
|
+
}
|
|
331
|
+
else {
|
|
332
|
+
/** @type {?} */
|
|
333
|
+
const tNode = getTNode(index, lView);
|
|
334
|
+
// inputs are only evaluated from a template binding into a directive, therefore,
|
|
335
|
+
// there should not be a situation where a directive host bindings function
|
|
336
|
+
// evaluates the inputs (this should only happen in the template function)
|
|
337
|
+
if (hasClassInput(tNode) && classes !== NO_CHANGE) {
|
|
338
|
+
/** @type {?} */
|
|
339
|
+
const initialClasses = getInitialClassNameValue(stylingContext);
|
|
340
|
+
/** @type {?} */
|
|
341
|
+
const classInputVal = (initialClasses.length ? (initialClasses + ' ') : '') + forceClassesAsString(classes);
|
|
342
|
+
setInputsForProperty(lView, (/** @type {?} */ ((/** @type {?} */ (tNode.inputs))['class'])), classInputVal);
|
|
343
|
+
classes = NO_CHANGE;
|
|
344
|
+
}
|
|
345
|
+
updateClassMap(stylingContext, classes);
|
|
346
|
+
}
|
|
347
|
+
if (runtimeIsNewStylingInUse()) {
|
|
348
|
+
newClassMap(classes);
|
|
349
|
+
}
|
|
382
350
|
}
|
|
383
351
|
/**
|
|
384
352
|
* Apply all style and class binding values to the element.
|
|
385
353
|
*
|
|
386
|
-
* This instruction is meant to be run after `
|
|
387
|
-
* or `
|
|
388
|
-
* the element if any styling bindings have been updated.
|
|
354
|
+
* This instruction is meant to be run after `styleMap`, `classMap`,
|
|
355
|
+
* `styleProp` or `classProp` instructions have been run and will
|
|
356
|
+
* only apply styling to the element if any styling bindings have been updated.
|
|
389
357
|
*
|
|
390
358
|
* \@codeGenApi
|
|
391
|
-
* @param {?} index Index of the element's with which styling is associated.
|
|
392
|
-
*
|
|
393
359
|
* @return {?}
|
|
394
360
|
*/
|
|
395
|
-
export function
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
/**
|
|
399
|
-
|
|
400
|
-
*
|
|
401
|
-
* This instruction is meant to be run after `elementHostStylingMap`,
|
|
402
|
-
* `elementHostStyleProp` or `elementHostClassProp` instructions have
|
|
403
|
-
* been run and will only apply styling to the host element if any
|
|
404
|
-
* styling bindings have been updated.
|
|
405
|
-
*
|
|
406
|
-
* \@codeGenApi
|
|
407
|
-
* @return {?}
|
|
408
|
-
*/
|
|
409
|
-
export function ɵɵelementHostStylingApply() {
|
|
410
|
-
elementStylingApplyInternal(getActiveDirectiveStylingIndex(), getSelectedIndex());
|
|
411
|
-
}
|
|
412
|
-
/**
|
|
413
|
-
* @param {?} directiveStylingIndex
|
|
414
|
-
* @param {?} index
|
|
415
|
-
* @return {?}
|
|
416
|
-
*/
|
|
417
|
-
export function elementStylingApplyInternal(directiveStylingIndex, index) {
|
|
361
|
+
export function ɵɵstylingApply() {
|
|
362
|
+
/** @type {?} */
|
|
363
|
+
const index = getSelectedIndex();
|
|
364
|
+
/** @type {?} */
|
|
365
|
+
const directiveStylingIndex = getActiveDirectiveStylingIndex() || DEFAULT_TEMPLATE_DIRECTIVE_INDEX;
|
|
418
366
|
/** @type {?} */
|
|
419
367
|
const lView = getLView();
|
|
420
368
|
/** @type {?} */
|
|
@@ -428,12 +376,14 @@ export function elementStylingApplyInternal(directiveStylingIndex, index) {
|
|
|
428
376
|
const isFirstRender = (lView[FLAGS] & 8 /* FirstLViewPass */) !== 0;
|
|
429
377
|
/** @type {?} */
|
|
430
378
|
const stylingContext = getStylingContext(index, lView);
|
|
431
|
-
|
|
432
|
-
const totalPlayersQueued = renderStyling(stylingContext, renderer, lView, isFirstRender, null, null, directiveStylingIndex);
|
|
433
|
-
if (totalPlayersQueued > 0) {
|
|
379
|
+
if (runtimeAllowOldStyling()) {
|
|
434
380
|
/** @type {?} */
|
|
435
|
-
const
|
|
436
|
-
|
|
381
|
+
const totalPlayersQueued = renderStyling(stylingContext, renderer, lView, isFirstRender, null, null, directiveStylingIndex);
|
|
382
|
+
if (totalPlayersQueued > 0) {
|
|
383
|
+
/** @type {?} */
|
|
384
|
+
const rootContext = getRootContext(lView);
|
|
385
|
+
scheduleTick(rootContext, 2 /* FlushPlayers */);
|
|
386
|
+
}
|
|
437
387
|
}
|
|
438
388
|
// because select(n) may not run between every instruction, the cached styling
|
|
439
389
|
// context may not get cleared between elements. The reason for this is because
|
|
@@ -443,6 +393,9 @@ export function elementStylingApplyInternal(directiveStylingIndex, index) {
|
|
|
443
393
|
// cleared because there is no code in Angular that applies more styling code after a
|
|
444
394
|
// styling flush has occurred. Note that this will be fixed once FW-1254 lands.
|
|
445
395
|
setCachedStylingContext(null);
|
|
396
|
+
if (runtimeIsNewStylingInUse()) {
|
|
397
|
+
newStylingApply();
|
|
398
|
+
}
|
|
446
399
|
}
|
|
447
400
|
/**
|
|
448
401
|
* @return {?}
|
|
@@ -475,4 +428,4 @@ function getStylingContext(index, lView) {
|
|
|
475
428
|
}
|
|
476
429
|
return context;
|
|
477
430
|
}
|
|
478
|
-
//# 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"]}
|
|
431
|
+
//# 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"]}
|