@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
|
@@ -0,0 +1,366 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @fileoverview added by tsickle
|
|
3
|
+
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
|
|
4
|
+
*/
|
|
5
|
+
import { BINDING_INDEX, HEADER_OFFSET, HOST, RENDERER } from '../interfaces/view';
|
|
6
|
+
import { getActiveDirectiveId, getActiveDirectiveSuperClassDepth, getActiveDirectiveSuperClassHeight, getLView, getSelectedIndex } from '../state';
|
|
7
|
+
import { NO_CHANGE } from '../tokens';
|
|
8
|
+
import { renderStringify } from '../util/misc_utils';
|
|
9
|
+
import { getTNode, isStylingContext as isOldStylingContext } from '../util/view_utils';
|
|
10
|
+
import { applyClasses, applyStyles, registerBinding, updateClassBinding, updateStyleBinding } from './bindings';
|
|
11
|
+
import { activeStylingMapFeature, normalizeIntoStylingMap } from './map_based_bindings';
|
|
12
|
+
import { setCurrentStyleSanitizer } from './state';
|
|
13
|
+
import { attachStylingDebugObject } from './styling_debug';
|
|
14
|
+
import { allocTStylingContext, getCurrentOrLViewSanitizer, hasValueChanged, updateContextDirectiveIndex } from './util';
|
|
15
|
+
/**
|
|
16
|
+
* --------
|
|
17
|
+
*
|
|
18
|
+
* This file contains the core logic for how styling instructions are processed in Angular.
|
|
19
|
+
*
|
|
20
|
+
* To learn more about the algorithm see `TStylingContext`.
|
|
21
|
+
*
|
|
22
|
+
* --------
|
|
23
|
+
*/
|
|
24
|
+
/**
|
|
25
|
+
* Temporary function to bridge styling functionality between this new
|
|
26
|
+
* refactor (which is here inside of `styling_next/`) and the old
|
|
27
|
+
* implementation (which lives inside of `styling/`).
|
|
28
|
+
*
|
|
29
|
+
* This function is executed during the creation block of an element.
|
|
30
|
+
* Because the existing styling implementation issues a call to the
|
|
31
|
+
* `styling()` instruction, this instruction will also get run. The
|
|
32
|
+
* central idea here is that the directive index values are bound
|
|
33
|
+
* into the context. The directive index is temporary and is only
|
|
34
|
+
* required until the `select(n)` instruction is fully functional.
|
|
35
|
+
* @return {?}
|
|
36
|
+
*/
|
|
37
|
+
export function stylingInit() {
|
|
38
|
+
/** @type {?} */
|
|
39
|
+
const lView = getLView();
|
|
40
|
+
/** @type {?} */
|
|
41
|
+
const index = getSelectedIndex();
|
|
42
|
+
/** @type {?} */
|
|
43
|
+
const tNode = getTNode(index, lView);
|
|
44
|
+
updateLastDirectiveIndex(tNode, getActiveDirectiveStylingIndex());
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Sets the current style sanitizer function which will then be used
|
|
48
|
+
* within all follow-up prop and map-based style binding instructions
|
|
49
|
+
* for the given element.
|
|
50
|
+
*
|
|
51
|
+
* Note that once styling has been applied to the element (i.e. once
|
|
52
|
+
* `select(n)` is executed or the hostBindings/template function exits)
|
|
53
|
+
* then the active `sanitizerFn` will be set to `null`. This means that
|
|
54
|
+
* once styling is applied to another element then a another call to
|
|
55
|
+
* `styleSanitizer` will need to be made.
|
|
56
|
+
*
|
|
57
|
+
* \@codeGenApi
|
|
58
|
+
* @param {?} sanitizer
|
|
59
|
+
* @return {?}
|
|
60
|
+
*/
|
|
61
|
+
export function styleSanitizer(sanitizer) {
|
|
62
|
+
setCurrentStyleSanitizer(sanitizer);
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Mirror implementation of the `styleProp()` instruction (found in `instructions/styling.ts`).
|
|
66
|
+
* @param {?} prop
|
|
67
|
+
* @param {?} value
|
|
68
|
+
* @param {?=} suffix
|
|
69
|
+
* @return {?}
|
|
70
|
+
*/
|
|
71
|
+
export function styleProp(prop, value, suffix) {
|
|
72
|
+
_stylingProp(prop, resolveStylePropValue(value, suffix), false);
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Mirror implementation of the `classProp()` instruction (found in `instructions/styling.ts`).
|
|
76
|
+
* @param {?} className
|
|
77
|
+
* @param {?} value
|
|
78
|
+
* @return {?}
|
|
79
|
+
*/
|
|
80
|
+
export function classProp(className, value) {
|
|
81
|
+
_stylingProp(className, value, true);
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Shared function used to update a prop-based styling binding for an element.
|
|
85
|
+
* @param {?} prop
|
|
86
|
+
* @param {?} value
|
|
87
|
+
* @param {?} isClassBased
|
|
88
|
+
* @return {?}
|
|
89
|
+
*/
|
|
90
|
+
function _stylingProp(prop, value, isClassBased) {
|
|
91
|
+
/** @type {?} */
|
|
92
|
+
const index = getSelectedIndex();
|
|
93
|
+
/** @type {?} */
|
|
94
|
+
const lView = getLView();
|
|
95
|
+
/** @type {?} */
|
|
96
|
+
const bindingIndex = lView[BINDING_INDEX]++;
|
|
97
|
+
/** @type {?} */
|
|
98
|
+
const tNode = getTNode(index, lView);
|
|
99
|
+
/** @type {?} */
|
|
100
|
+
const defer = getActiveDirectiveSuperClassHeight() > 0;
|
|
101
|
+
if (isClassBased) {
|
|
102
|
+
updateClassBinding(getClassesContext(tNode), lView, prop, bindingIndex, (/** @type {?} */ (value)), defer, false);
|
|
103
|
+
}
|
|
104
|
+
else {
|
|
105
|
+
/** @type {?} */
|
|
106
|
+
const sanitizer = getCurrentOrLViewSanitizer(lView);
|
|
107
|
+
updateStyleBinding(getStylesContext(tNode), lView, prop, bindingIndex, (/** @type {?} */ (value)), sanitizer, defer, false);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
/**
|
|
111
|
+
* Mirror implementation of the `styleMap()` instruction (found in `instructions/styling.ts`).
|
|
112
|
+
* @param {?} styles
|
|
113
|
+
* @return {?}
|
|
114
|
+
*/
|
|
115
|
+
export function styleMap(styles) {
|
|
116
|
+
_stylingMap(styles, false);
|
|
117
|
+
}
|
|
118
|
+
/**
|
|
119
|
+
* Mirror implementation of the `classMap()` instruction (found in `instructions/styling.ts`).
|
|
120
|
+
* @param {?} classes
|
|
121
|
+
* @return {?}
|
|
122
|
+
*/
|
|
123
|
+
export function classMap(classes) {
|
|
124
|
+
_stylingMap(classes, true);
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* Shared function used to update a map-based styling binding for an element.
|
|
128
|
+
*
|
|
129
|
+
* When this function is called it will activate support for `[style]` and
|
|
130
|
+
* `[class]` bindings in Angular.
|
|
131
|
+
* @param {?} value
|
|
132
|
+
* @param {?} isClassBased
|
|
133
|
+
* @return {?}
|
|
134
|
+
*/
|
|
135
|
+
function _stylingMap(value, isClassBased) {
|
|
136
|
+
activeStylingMapFeature();
|
|
137
|
+
/** @type {?} */
|
|
138
|
+
const index = getSelectedIndex();
|
|
139
|
+
/** @type {?} */
|
|
140
|
+
const lView = getLView();
|
|
141
|
+
/** @type {?} */
|
|
142
|
+
const bindingIndex = lView[BINDING_INDEX]++;
|
|
143
|
+
if (value !== NO_CHANGE) {
|
|
144
|
+
/** @type {?} */
|
|
145
|
+
const tNode = getTNode(index, lView);
|
|
146
|
+
/** @type {?} */
|
|
147
|
+
const defer = getActiveDirectiveSuperClassHeight() > 0;
|
|
148
|
+
/** @type {?} */
|
|
149
|
+
const oldValue = lView[bindingIndex];
|
|
150
|
+
/** @type {?} */
|
|
151
|
+
const valueHasChanged = hasValueChanged(oldValue, value);
|
|
152
|
+
/** @type {?} */
|
|
153
|
+
const lStylingMap = normalizeIntoStylingMap(oldValue, value);
|
|
154
|
+
if (isClassBased) {
|
|
155
|
+
updateClassBinding(getClassesContext(tNode), lView, null, bindingIndex, lStylingMap, defer, valueHasChanged);
|
|
156
|
+
}
|
|
157
|
+
else {
|
|
158
|
+
/** @type {?} */
|
|
159
|
+
const sanitizer = getCurrentOrLViewSanitizer(lView);
|
|
160
|
+
updateStyleBinding(getStylesContext(tNode), lView, null, bindingIndex, lStylingMap, sanitizer, defer, valueHasChanged);
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
/**
|
|
165
|
+
* Temporary function to bridge styling functionality between this new
|
|
166
|
+
* refactor (which is here inside of `styling_next/`) and the old
|
|
167
|
+
* implementation (which lives inside of `styling/`).
|
|
168
|
+
*
|
|
169
|
+
* The new styling refactor ensures that styling flushing is called
|
|
170
|
+
* automatically when a template function exits or a follow-up element
|
|
171
|
+
* is visited (i.e. when `select(n)` is called). Because the `select(n)`
|
|
172
|
+
* instruction is not fully implemented yet (it doesn't actually execute
|
|
173
|
+
* host binding instruction code at the right time), this means that a
|
|
174
|
+
* styling apply function is still needed.
|
|
175
|
+
*
|
|
176
|
+
* This function is a mirror implementation of the `stylingApply()`
|
|
177
|
+
* instruction (found in `instructions/styling.ts`).
|
|
178
|
+
* @return {?}
|
|
179
|
+
*/
|
|
180
|
+
export function stylingApply() {
|
|
181
|
+
/** @type {?} */
|
|
182
|
+
const index = getSelectedIndex();
|
|
183
|
+
/** @type {?} */
|
|
184
|
+
const lView = getLView();
|
|
185
|
+
/** @type {?} */
|
|
186
|
+
const tNode = getTNode(index, lView);
|
|
187
|
+
/** @type {?} */
|
|
188
|
+
const renderer = getRenderer(tNode, lView);
|
|
189
|
+
/** @type {?} */
|
|
190
|
+
const native = getNativeFromLView(index, lView);
|
|
191
|
+
/** @type {?} */
|
|
192
|
+
const directiveIndex = getActiveDirectiveStylingIndex();
|
|
193
|
+
applyClasses(renderer, lView, getClassesContext(tNode), native, directiveIndex);
|
|
194
|
+
/** @type {?} */
|
|
195
|
+
const sanitizer = getCurrentOrLViewSanitizer(lView);
|
|
196
|
+
applyStyles(renderer, lView, getStylesContext(tNode), native, directiveIndex, sanitizer);
|
|
197
|
+
setCurrentStyleSanitizer(null);
|
|
198
|
+
}
|
|
199
|
+
/**
|
|
200
|
+
* Temporary function to bridge styling functionality between this new
|
|
201
|
+
* refactor (which is here inside of `styling_next/`) and the old
|
|
202
|
+
* implementation (which lives inside of `styling/`).
|
|
203
|
+
*
|
|
204
|
+
* The purpose of this function is to traverse through the LView data
|
|
205
|
+
* for a specific element index and return the native node. Because the
|
|
206
|
+
* current implementation relies on there being a styling context array,
|
|
207
|
+
* the code below will need to loop through these array values until it
|
|
208
|
+
* gets a native element node.
|
|
209
|
+
*
|
|
210
|
+
* Note that this code is temporary and will disappear once the new
|
|
211
|
+
* styling refactor lands in its entirety.
|
|
212
|
+
* @param {?} index
|
|
213
|
+
* @param {?} viewData
|
|
214
|
+
* @return {?}
|
|
215
|
+
*/
|
|
216
|
+
function getNativeFromLView(index, viewData) {
|
|
217
|
+
/** @type {?} */
|
|
218
|
+
let storageIndex = index + HEADER_OFFSET;
|
|
219
|
+
/** @type {?} */
|
|
220
|
+
let slotValue = viewData[storageIndex];
|
|
221
|
+
/** @type {?} */
|
|
222
|
+
let wrapper = viewData;
|
|
223
|
+
while (Array.isArray(slotValue)) {
|
|
224
|
+
wrapper = slotValue;
|
|
225
|
+
slotValue = (/** @type {?} */ (slotValue[HOST]));
|
|
226
|
+
}
|
|
227
|
+
if (isOldStylingContext(wrapper)) {
|
|
228
|
+
return (/** @type {?} */ (wrapper[0 /* ElementPosition */]));
|
|
229
|
+
}
|
|
230
|
+
else {
|
|
231
|
+
return slotValue;
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
/**
|
|
235
|
+
* @param {?} tNode
|
|
236
|
+
* @param {?} lView
|
|
237
|
+
* @return {?}
|
|
238
|
+
*/
|
|
239
|
+
function getRenderer(tNode, lView) {
|
|
240
|
+
return tNode.type === 3 /* Element */ ? lView[RENDERER] : null;
|
|
241
|
+
}
|
|
242
|
+
/**
|
|
243
|
+
* Searches and assigns provided all static style/class entries (found in the `attrs` value)
|
|
244
|
+
* and registers them in their respective styling contexts.
|
|
245
|
+
* @param {?} tNode
|
|
246
|
+
* @param {?} attrs
|
|
247
|
+
* @param {?} startIndex
|
|
248
|
+
* @return {?}
|
|
249
|
+
*/
|
|
250
|
+
export function registerInitialStylingIntoContext(tNode, attrs, startIndex) {
|
|
251
|
+
/** @type {?} */
|
|
252
|
+
let classesContext;
|
|
253
|
+
/** @type {?} */
|
|
254
|
+
let stylesContext;
|
|
255
|
+
/** @type {?} */
|
|
256
|
+
let mode = -1;
|
|
257
|
+
for (let i = startIndex; i < attrs.length; i++) {
|
|
258
|
+
/** @type {?} */
|
|
259
|
+
const attr = attrs[i];
|
|
260
|
+
if (typeof attr == 'number') {
|
|
261
|
+
mode = attr;
|
|
262
|
+
}
|
|
263
|
+
else if (mode == 1 /* Classes */) {
|
|
264
|
+
classesContext = classesContext || getClassesContext(tNode);
|
|
265
|
+
registerBinding(classesContext, -1, (/** @type {?} */ (attr)), true, false);
|
|
266
|
+
}
|
|
267
|
+
else if (mode == 2 /* Styles */) {
|
|
268
|
+
stylesContext = stylesContext || getStylesContext(tNode);
|
|
269
|
+
registerBinding(stylesContext, -1, (/** @type {?} */ (attr)), (/** @type {?} */ (attrs[++i])), false);
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
/**
|
|
274
|
+
* Mirror implementation of the same function found in `instructions/styling.ts`.
|
|
275
|
+
* @return {?}
|
|
276
|
+
*/
|
|
277
|
+
export function getActiveDirectiveStylingIndex() {
|
|
278
|
+
// whenever a directive's hostBindings function is called a uniqueId value
|
|
279
|
+
// is assigned. Normally this is enough to help distinguish one directive
|
|
280
|
+
// from another for the styling context, but there are situations where a
|
|
281
|
+
// sub-class directive could inherit and assign styling in concert with a
|
|
282
|
+
// parent directive. To help the styling code distinguish between a parent
|
|
283
|
+
// sub-classed directive the inheritance depth is taken into account as well.
|
|
284
|
+
return getActiveDirectiveId() + getActiveDirectiveSuperClassDepth();
|
|
285
|
+
}
|
|
286
|
+
/**
|
|
287
|
+
* Temporary function that will update the max directive index value in
|
|
288
|
+
* both the classes and styles contexts present on the provided `tNode`.
|
|
289
|
+
*
|
|
290
|
+
* This code is only used because the `select(n)` code functionality is not
|
|
291
|
+
* yet 100% functional. The `select(n)` instruction cannot yet evaluate host
|
|
292
|
+
* bindings function code in sync with the associated template function code.
|
|
293
|
+
* For this reason the styling algorithm needs to track the last directive index
|
|
294
|
+
* value so that it knows exactly when to render styling to the element since
|
|
295
|
+
* `stylingApply()` is called multiple times per CD (`stylingApply` will be
|
|
296
|
+
* removed once `select(n)` is fixed).
|
|
297
|
+
* @param {?} tNode
|
|
298
|
+
* @param {?} directiveIndex
|
|
299
|
+
* @return {?}
|
|
300
|
+
*/
|
|
301
|
+
function updateLastDirectiveIndex(tNode, directiveIndex) {
|
|
302
|
+
updateContextDirectiveIndex(getClassesContext(tNode), directiveIndex);
|
|
303
|
+
updateContextDirectiveIndex(getStylesContext(tNode), directiveIndex);
|
|
304
|
+
}
|
|
305
|
+
/**
|
|
306
|
+
* @param {?} tNode
|
|
307
|
+
* @return {?}
|
|
308
|
+
*/
|
|
309
|
+
function getStylesContext(tNode) {
|
|
310
|
+
return getContext(tNode, false);
|
|
311
|
+
}
|
|
312
|
+
/**
|
|
313
|
+
* @param {?} tNode
|
|
314
|
+
* @return {?}
|
|
315
|
+
*/
|
|
316
|
+
function getClassesContext(tNode) {
|
|
317
|
+
return getContext(tNode, true);
|
|
318
|
+
}
|
|
319
|
+
/**
|
|
320
|
+
* Returns/instantiates a styling context from/to a `tNode` instance.
|
|
321
|
+
* @param {?} tNode
|
|
322
|
+
* @param {?} isClassBased
|
|
323
|
+
* @return {?}
|
|
324
|
+
*/
|
|
325
|
+
function getContext(tNode, isClassBased) {
|
|
326
|
+
/** @type {?} */
|
|
327
|
+
let context = isClassBased ? tNode.newClasses : tNode.newStyles;
|
|
328
|
+
if (!context) {
|
|
329
|
+
context = allocTStylingContext();
|
|
330
|
+
if (ngDevMode) {
|
|
331
|
+
attachStylingDebugObject(context);
|
|
332
|
+
}
|
|
333
|
+
if (isClassBased) {
|
|
334
|
+
tNode.newClasses = context;
|
|
335
|
+
}
|
|
336
|
+
else {
|
|
337
|
+
tNode.newStyles = context;
|
|
338
|
+
}
|
|
339
|
+
}
|
|
340
|
+
return context;
|
|
341
|
+
}
|
|
342
|
+
/**
|
|
343
|
+
* @param {?} value
|
|
344
|
+
* @param {?} suffix
|
|
345
|
+
* @return {?}
|
|
346
|
+
*/
|
|
347
|
+
function resolveStylePropValue(value, suffix) {
|
|
348
|
+
/** @type {?} */
|
|
349
|
+
let resolvedValue = null;
|
|
350
|
+
if (value !== null) {
|
|
351
|
+
if (suffix) {
|
|
352
|
+
// when a suffix is applied then it will bypass
|
|
353
|
+
// sanitization entirely (b/c a new string is created)
|
|
354
|
+
resolvedValue = renderStringify(value) + suffix;
|
|
355
|
+
}
|
|
356
|
+
else {
|
|
357
|
+
// sanitization happens by dealing with a String value
|
|
358
|
+
// this means that the string value will be passed through
|
|
359
|
+
// into the style rendering later (which is where the value
|
|
360
|
+
// will be sanitized before it is applied)
|
|
361
|
+
resolvedValue = (/** @type {?} */ ((/** @type {?} */ (value))));
|
|
362
|
+
}
|
|
363
|
+
}
|
|
364
|
+
return resolvedValue;
|
|
365
|
+
}
|
|
366
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"instructions.js","sourceRoot":"","sources":["../../../../../../../../packages/core/src/render3/styling_next/instructions.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n* @license\n* Copyright Google Inc. All Rights Reserved.\n*\n* Use of this source code is governed by an MIT-style license that can be\n* found in the LICENSE file at https://angular.io/license\n*/\nimport {Sanitizer} from '../../sanitization/security';\nimport {StyleSanitizeFn} from '../../sanitization/style_sanitizer';\nimport {LContainer} from '../interfaces/container';\nimport {AttributeMarker, TAttributes, TNode, TNodeType} from '../interfaces/node';\nimport {RElement} from '../interfaces/renderer';\nimport {StylingContext as OldStylingContext, StylingIndex as OldStylingIndex} from '../interfaces/styling';\nimport {BINDING_INDEX, HEADER_OFFSET, HOST, LView, RENDERER, SANITIZER} from '../interfaces/view';\nimport {getActiveDirectiveId, getActiveDirectiveSuperClassDepth, getActiveDirectiveSuperClassHeight, getLView, getSelectedIndex} from '../state';\nimport {NO_CHANGE} from '../tokens';\nimport {renderStringify} from '../util/misc_utils';\nimport {getTNode, isStylingContext as isOldStylingContext} from '../util/view_utils';\n\nimport {applyClasses, applyStyles, registerBinding, updateClassBinding, updateStyleBinding} from './bindings';\nimport {TStylingContext} from './interfaces';\nimport {activeStylingMapFeature, normalizeIntoStylingMap} from './map_based_bindings';\nimport {getCurrentStyleSanitizer, setCurrentStyleSanitizer} from './state';\nimport {attachStylingDebugObject} from './styling_debug';\nimport {allocTStylingContext, getCurrentOrLViewSanitizer, hasValueChanged, updateContextDirectiveIndex} from './util';\n\n\n\n/**\n * --------\n *\n * This file contains the core logic for how styling instructions are processed in Angular.\n *\n * To learn more about the algorithm see `TStylingContext`.\n *\n * --------\n */\n\n/**\n * Temporary function to bridge styling functionality between this new\n * refactor (which is here inside of `styling_next/`) and the old\n * implementation (which lives inside of `styling/`).\n *\n * This function is executed during the creation block of an element.\n * Because the existing styling implementation issues a call to the\n * `styling()` instruction, this instruction will also get run. The\n * central idea here is that the directive index values are bound\n * into the context. The directive index is temporary and is only\n * required until the `select(n)` instruction is fully functional.\n */\nexport function stylingInit() {\n  const lView = getLView();\n  const index = getSelectedIndex();\n  const tNode = getTNode(index, lView);\n  updateLastDirectiveIndex(tNode, getActiveDirectiveStylingIndex());\n}\n\n/**\n * Sets the current style sanitizer function which will then be used\n * within all follow-up prop and map-based style binding instructions\n * for the given element.\n *\n * Note that once styling has been applied to the element (i.e. once\n * `select(n)` is executed or the hostBindings/template function exits)\n * then the active `sanitizerFn` will be set to `null`. This means that\n * once styling is applied to another element then a another call to\n * `styleSanitizer` will need to be made.\n *\n * @param sanitizerFn The sanitization function that will be used to\n *       process style prop/value entries.\n *\n * @codeGenApi\n */\nexport function styleSanitizer(sanitizer: Sanitizer | StyleSanitizeFn | null): void {\n  setCurrentStyleSanitizer(sanitizer);\n}\n\n/**\n * Mirror implementation of the `styleProp()` instruction (found in `instructions/styling.ts`).\n */\nexport function styleProp(\n    prop: string, value: string | number | String | null, suffix?: string | null): void {\n  _stylingProp(prop, resolveStylePropValue(value, suffix), false);\n}\n\n/**\n * Mirror implementation of the `classProp()` instruction (found in `instructions/styling.ts`).\n */\nexport function classProp(className: string, value: boolean | null): void {\n  _stylingProp(className, value, true);\n}\n\n/**\n * Shared function used to update a prop-based styling binding for an element.\n */\nfunction _stylingProp(\n    prop: string, value: boolean | number | String | string | null, isClassBased: boolean) {\n  const index = getSelectedIndex();\n  const lView = getLView();\n  const bindingIndex = lView[BINDING_INDEX]++;\n  const tNode = getTNode(index, lView);\n  const defer = getActiveDirectiveSuperClassHeight() > 0;\n  if (isClassBased) {\n    updateClassBinding(\n        getClassesContext(tNode), lView, prop, bindingIndex, value as string | boolean | null,\n        defer, false);\n  } else {\n    const sanitizer = getCurrentOrLViewSanitizer(lView);\n    updateStyleBinding(\n        getStylesContext(tNode), lView, prop, bindingIndex, value as string | null, sanitizer,\n        defer, false);\n  }\n}\n\n/**\n * Mirror implementation of the `styleMap()` instruction (found in `instructions/styling.ts`).\n */\nexport function styleMap(styles: {[styleName: string]: any} | NO_CHANGE | null): void {\n  _stylingMap(styles, false);\n}\n\n/**\n * Mirror implementation of the `classMap()` instruction (found in `instructions/styling.ts`).\n */\nexport function classMap(classes: {[className: string]: any} | NO_CHANGE | string | null): void {\n  _stylingMap(classes, true);\n}\n\n/**\n * Shared function used to update a map-based styling binding for an element.\n *\n * When this function is called it will activate support for `[style]` and\n * `[class]` bindings in Angular.\n */\nfunction _stylingMap(value: {[key: string]: any} | string | null, isClassBased: boolean) {\n  activeStylingMapFeature();\n  const index = getSelectedIndex();\n  const lView = getLView();\n  const bindingIndex = lView[BINDING_INDEX]++;\n\n  if (value !== NO_CHANGE) {\n    const tNode = getTNode(index, lView);\n    const defer = getActiveDirectiveSuperClassHeight() > 0;\n    const oldValue = lView[bindingIndex];\n    const valueHasChanged = hasValueChanged(oldValue, value);\n    const lStylingMap = normalizeIntoStylingMap(oldValue, value);\n    if (isClassBased) {\n      updateClassBinding(\n          getClassesContext(tNode), lView, null, bindingIndex, lStylingMap, defer, valueHasChanged);\n    } else {\n      const sanitizer = getCurrentOrLViewSanitizer(lView);\n      updateStyleBinding(\n          getStylesContext(tNode), lView, null, bindingIndex, lStylingMap, sanitizer, defer,\n          valueHasChanged);\n    }\n  }\n}\n\n/**\n * Temporary function to bridge styling functionality between this new\n * refactor (which is here inside of `styling_next/`) and the old\n * implementation (which lives inside of `styling/`).\n *\n * The new styling refactor ensures that styling flushing is called\n * automatically when a template function exits or a follow-up element\n * is visited (i.e. when `select(n)` is called). Because the `select(n)`\n * instruction is not fully implemented yet (it doesn't actually execute\n * host binding instruction code at the right time), this means that a\n * styling apply function is still needed.\n *\n * This function is a mirror implementation of the `stylingApply()`\n * instruction (found in `instructions/styling.ts`).\n */\nexport function stylingApply() {\n  const index = getSelectedIndex();\n  const lView = getLView();\n  const tNode = getTNode(index, lView);\n  const renderer = getRenderer(tNode, lView);\n  const native = getNativeFromLView(index, lView);\n  const directiveIndex = getActiveDirectiveStylingIndex();\n  applyClasses(renderer, lView, getClassesContext(tNode), native, directiveIndex);\n\n  const sanitizer = getCurrentOrLViewSanitizer(lView);\n  applyStyles(renderer, lView, getStylesContext(tNode), native, directiveIndex, sanitizer);\n\n  setCurrentStyleSanitizer(null);\n}\n\n/**\n * Temporary function to bridge styling functionality between this new\n * refactor (which is here inside of `styling_next/`) and the old\n * implementation (which lives inside of `styling/`).\n *\n * The purpose of this function is to traverse through the LView data\n * for a specific element index and return the native node. Because the\n * current implementation relies on there being a styling context array,\n * the code below will need to loop through these array values until it\n * gets a native element node.\n *\n * Note that this code is temporary and will disappear once the new\n * styling refactor lands in its entirety.\n */\nfunction getNativeFromLView(index: number, viewData: LView): RElement {\n  let storageIndex = index + HEADER_OFFSET;\n  let slotValue: LContainer|LView|OldStylingContext|RElement = viewData[storageIndex];\n  let wrapper: LContainer|LView|OldStylingContext = viewData;\n  while (Array.isArray(slotValue)) {\n    wrapper = slotValue;\n    slotValue = slotValue[HOST] as LView | OldStylingContext | RElement;\n  }\n  if (isOldStylingContext(wrapper)) {\n    return wrapper[OldStylingIndex.ElementPosition] as RElement;\n  } else {\n    return slotValue;\n  }\n}\n\nfunction getRenderer(tNode: TNode, lView: LView) {\n  return tNode.type === TNodeType.Element ? lView[RENDERER] : null;\n}\n\n/**\n * Searches and assigns provided all static style/class entries (found in the `attrs` value)\n * and registers them in their respective styling contexts.\n */\nexport function registerInitialStylingIntoContext(\n    tNode: TNode, attrs: TAttributes, startIndex: number) {\n  let classesContext !: TStylingContext;\n  let stylesContext !: TStylingContext;\n  let mode = -1;\n  for (let i = startIndex; i < attrs.length; i++) {\n    const attr = attrs[i];\n    if (typeof attr == 'number') {\n      mode = attr;\n    } else if (mode == AttributeMarker.Classes) {\n      classesContext = classesContext || getClassesContext(tNode);\n      registerBinding(classesContext, -1, attr as string, true, false);\n    } else if (mode == AttributeMarker.Styles) {\n      stylesContext = stylesContext || getStylesContext(tNode);\n      registerBinding(stylesContext, -1, attr as string, attrs[++i] as string, false);\n    }\n  }\n}\n\n/**\n * Mirror implementation of the same function found in `instructions/styling.ts`.\n */\nexport function getActiveDirectiveStylingIndex(): number {\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\n/**\n * Temporary function that will update the max directive index value in\n * both the classes and styles contexts present on the provided `tNode`.\n *\n * This code is only used because the `select(n)` code functionality is not\n * yet 100% functional. The `select(n)` instruction cannot yet evaluate host\n * bindings function code in sync with the associated template function code.\n * For this reason the styling algorithm needs to track the last directive index\n * value so that it knows exactly when to render styling to the element since\n * `stylingApply()` is called multiple times per CD (`stylingApply` will be\n * removed once `select(n)` is fixed).\n */\nfunction updateLastDirectiveIndex(tNode: TNode, directiveIndex: number) {\n  updateContextDirectiveIndex(getClassesContext(tNode), directiveIndex);\n  updateContextDirectiveIndex(getStylesContext(tNode), directiveIndex);\n}\n\nfunction getStylesContext(tNode: TNode): TStylingContext {\n  return getContext(tNode, false);\n}\n\nfunction getClassesContext(tNode: TNode): TStylingContext {\n  return getContext(tNode, true);\n}\n\n/**\n * Returns/instantiates a styling context from/to a `tNode` instance.\n */\nfunction getContext(tNode: TNode, isClassBased: boolean) {\n  let context = isClassBased ? tNode.newClasses : tNode.newStyles;\n  if (!context) {\n    context = allocTStylingContext();\n    if (ngDevMode) {\n      attachStylingDebugObject(context);\n    }\n    if (isClassBased) {\n      tNode.newClasses = context;\n    } else {\n      tNode.newStyles = context;\n    }\n  }\n  return context;\n}\n\nfunction resolveStylePropValue(\n    value: string | number | String | null, suffix: string | null | undefined) {\n  let resolvedValue: 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      resolvedValue = 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      resolvedValue = value as any as string;\n    }\n  }\n  return resolvedValue;\n}\n"]}
|