@angular/core 9.0.0-rc.7 → 9.0.1
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 +18 -16
- package/bundles/core-testing.umd.js.map +1 -1
- package/bundles/core-testing.umd.min.js +7 -7
- package/bundles/core-testing.umd.min.js.map +1 -1
- package/bundles/core.umd.js +6386 -6384
- package/bundles/core.umd.js.map +1 -1
- package/bundles/core.umd.min.js +182 -175
- package/bundles/core.umd.min.js.map +1 -1
- package/core.d.ts +726 -734
- package/core.metadata.json +1 -1
- package/esm2015/core.externs.js +5 -5
- package/esm2015/core.js +17 -15
- package/esm2015/index.js +2 -2
- package/esm2015/public_api.js +2 -2
- package/esm2015/src/application_init.js +10 -2
- package/esm2015/src/application_module.js +6 -3
- package/esm2015/src/application_ref.js +7 -7
- package/esm2015/src/core.js +4 -4
- package/esm2015/src/core_private_export.js +7 -7
- package/esm2015/src/core_render3_private_export.js +2 -2
- package/esm2015/src/debug/debug_node.js +55 -16
- package/esm2015/src/di/injectable.js +1 -13
- package/esm2015/src/di/injector.js +12 -10
- package/esm2015/src/di/interface/provider.js +1 -1
- package/esm2015/src/di/r3_injector.js +5 -4
- package/esm2015/src/i18n/locale_data_api.js +22 -6
- package/esm2015/src/i18n/locale_en.js +16 -5
- package/esm2015/src/i18n/localization.js +7 -1
- package/esm2015/src/i18n/tokens.js +41 -1
- package/esm2015/src/interface/type.js +1 -1
- package/esm2015/src/metadata/ng_module.js +1 -1
- package/esm2015/src/render/api.js +4 -1
- package/esm2015/src/render3/assert.js +9 -1
- package/esm2015/src/render3/bindings.js +16 -5
- package/esm2015/src/render3/component.js +54 -25
- package/esm2015/src/render3/component_ref.js +28 -18
- package/esm2015/src/render3/definition.js +3 -1
- package/esm2015/src/render3/di.js +3 -4
- package/esm2015/src/render3/di_setup.js +5 -7
- package/esm2015/src/render3/errors.js +3 -1
- package/esm2015/src/render3/features/inherit_definition_feature.js +89 -52
- package/esm2015/src/render3/features/ng_onchanges_feature.js +2 -2
- package/esm2015/src/render3/global_utils_api.js +3 -3
- package/esm2015/src/render3/i18n.js +60 -56
- package/esm2015/src/render3/index.js +2 -2
- package/esm2015/src/render3/instructions/advance.js +10 -11
- package/esm2015/src/render3/instructions/all.js +4 -5
- package/esm2015/src/render3/instructions/attribute.js +12 -5
- package/esm2015/src/render3/instructions/attribute_interpolation.js +66 -14
- package/esm2015/src/render3/instructions/change_detection.js +8 -23
- package/esm2015/src/render3/instructions/class_map_interpolation.js +13 -12
- package/esm2015/src/render3/instructions/container.js +15 -12
- package/esm2015/src/render3/instructions/element.js +45 -132
- package/esm2015/src/render3/instructions/element_container.js +8 -10
- package/esm2015/src/render3/instructions/embedded_view.js +7 -7
- package/esm2015/src/render3/instructions/host_property.js +10 -7
- package/esm2015/src/render3/instructions/listener.js +18 -16
- package/esm2015/src/render3/instructions/lview_debug.js +160 -23
- package/esm2015/src/render3/instructions/projection.js +7 -5
- package/esm2015/src/render3/instructions/property.js +27 -6
- package/esm2015/src/render3/instructions/property_interpolation.js +42 -23
- package/esm2015/src/render3/instructions/shared.js +279 -244
- package/esm2015/src/render3/instructions/storage.js +6 -8
- package/esm2015/src/render3/instructions/style_prop_interpolation.js +12 -12
- package/esm2015/src/render3/instructions/styling.js +731 -475
- package/esm2015/src/render3/instructions/text.js +5 -5
- package/esm2015/src/render3/interfaces/definition.js +41 -1
- package/esm2015/src/render3/interfaces/node.js +160 -115
- package/esm2015/src/render3/interfaces/styling.js +183 -375
- package/esm2015/src/render3/interfaces/view.js +10 -2
- package/esm2015/src/render3/jit/environment.js +1 -3
- package/esm2015/src/render3/namespaces.js +17 -0
- package/esm2015/src/render3/node_manipulation.js +177 -57
- package/esm2015/src/render3/node_selector_matcher.js +128 -24
- package/esm2015/src/render3/node_util.js +12 -7
- package/esm2015/src/render3/pipe.js +10 -14
- package/esm2015/src/render3/pure_function.js +107 -42
- package/esm2015/src/render3/query.js +32 -26
- package/esm2015/src/render3/state.js +57 -185
- package/esm2015/src/render3/styling/class_differ.js +47 -0
- package/esm2015/src/render3/styling/static_styling.js +54 -0
- package/esm2015/src/render3/styling/style_binding_list.js +437 -0
- package/esm2015/src/render3/styling/styling_parser.js +336 -0
- package/esm2015/src/render3/tokens.js +2 -2
- package/esm2015/src/render3/util/attrs_utils.js +125 -2
- package/esm2015/src/render3/util/change_detection_utils.js +33 -0
- package/esm2015/src/render3/util/discovery_utils.js +146 -119
- package/esm2015/src/render3/util/global_utils.js +5 -5
- package/esm2015/src/render3/util/view_utils.js +6 -6
- package/esm2015/src/render3/view_engine_compatibility.js +16 -17
- package/esm2015/src/render3/view_ref.js +16 -13
- package/esm2015/src/sanitization/bypass.js +1 -1
- package/esm2015/src/sanitization/sanitization.js +20 -5
- package/esm2015/src/util/array_utils.js +240 -1
- package/esm2015/src/util/assert.js +37 -21
- package/esm2015/src/util/char_code.js +8 -0
- package/esm2015/src/util/iterable.js +4 -1
- package/esm2015/src/util/ng_dev_mode.js +1 -12
- package/esm2015/src/util/stringify.js +14 -1
- package/esm2015/src/version.js +1 -1
- package/esm2015/src/view/services.js +1 -1
- package/esm2015/testing/src/r3_test_bed.js +5 -1
- package/esm2015/testing/src/r3_test_bed_compiler.js +5 -13
- package/esm2015/testing/src/styling.js +103 -0
- package/esm5/core.js +17 -15
- package/esm5/src/application_init.js +10 -2
- package/esm5/src/application_module.js +6 -3
- package/esm5/src/application_ref.js +6 -6
- package/esm5/src/core.js +2 -2
- package/esm5/src/core_private_export.js +7 -7
- package/esm5/src/core_render3_private_export.js +2 -2
- package/esm5/src/debug/debug_node.js +39 -14
- package/esm5/src/di/injectable.js +1 -1
- package/esm5/src/di/injector.js +12 -12
- package/esm5/src/di/interface/provider.js +1 -1
- package/esm5/src/di/r3_injector.js +5 -4
- package/esm5/src/i18n/locale_data_api.js +20 -6
- package/esm5/src/i18n/locale_en.js +16 -5
- package/esm5/src/i18n/localization.js +6 -1
- package/esm5/src/i18n/tokens.js +40 -1
- package/esm5/src/interface/type.js +1 -1
- package/esm5/src/metadata/ng_module.js +1 -1
- package/esm5/src/render/api.js +4 -1
- package/esm5/src/render3/assert.js +4 -1
- package/esm5/src/render3/bindings.js +19 -2
- package/esm5/src/render3/component.js +47 -22
- package/esm5/src/render3/component_ref.js +20 -17
- package/esm5/src/render3/definition.js +3 -1
- package/esm5/src/render3/di.js +3 -4
- package/esm5/src/render3/di_setup.js +4 -5
- package/esm5/src/render3/errors.js +3 -1
- package/esm5/src/render3/features/inherit_definition_feature.js +74 -42
- package/esm5/src/render3/features/ng_onchanges_feature.js +1 -1
- package/esm5/src/render3/global_utils_api.js +3 -3
- package/esm5/src/render3/i18n.js +51 -51
- package/esm5/src/render3/index.js +2 -2
- package/esm5/src/render3/instructions/advance.js +9 -11
- package/esm5/src/render3/instructions/all.js +1 -2
- package/esm5/src/render3/instructions/attribute.js +9 -5
- package/esm5/src/render3/instructions/attribute_interpolation.js +49 -13
- package/esm5/src/render3/instructions/change_detection.js +8 -21
- package/esm5/src/render3/instructions/class_map_interpolation.js +13 -12
- package/esm5/src/render3/instructions/container.js +13 -12
- package/esm5/src/render3/instructions/element.js +41 -113
- package/esm5/src/render3/instructions/element_container.js +8 -9
- package/esm5/src/render3/instructions/embedded_view.js +7 -7
- package/esm5/src/render3/instructions/host_property.js +8 -7
- package/esm5/src/render3/instructions/listener.js +13 -13
- package/esm5/src/render3/instructions/lview_debug.js +56 -15
- package/esm5/src/render3/instructions/projection.js +6 -5
- package/esm5/src/render3/instructions/property.js +17 -6
- package/esm5/src/render3/instructions/property_interpolation.js +32 -24
- package/esm5/src/render3/instructions/shared.js +258 -210
- package/esm5/src/render3/instructions/storage.js +4 -6
- package/esm5/src/render3/instructions/style_prop_interpolation.js +12 -12
- package/esm5/src/render3/instructions/styling.js +685 -367
- package/esm5/src/render3/instructions/text.js +5 -5
- package/esm5/src/render3/interfaces/definition.js +1 -1
- package/esm5/src/render3/interfaces/node.js +49 -1
- package/esm5/src/render3/interfaces/styling.js +57 -1
- package/esm5/src/render3/interfaces/view.js +1 -1
- package/esm5/src/render3/jit/environment.js +1 -3
- package/esm5/src/render3/namespaces.js +10 -0
- package/esm5/src/render3/node_manipulation.js +167 -54
- package/esm5/src/render3/node_selector_matcher.js +113 -20
- package/esm5/src/render3/node_util.js +12 -7
- package/esm5/src/render3/pipe.js +10 -14
- package/esm5/src/render3/pure_function.js +103 -33
- package/esm5/src/render3/query.js +25 -24
- package/esm5/src/render3/state.js +37 -133
- package/esm5/src/render3/styling/class_differ.js +39 -0
- package/esm5/src/render3/styling/static_styling.js +42 -0
- package/esm5/src/render3/styling/style_binding_list.js +411 -0
- package/esm5/src/render3/styling/styling_parser.js +265 -0
- package/esm5/src/render3/tokens.js +2 -2
- package/esm5/src/render3/util/attrs_utils.js +117 -2
- package/esm5/src/render3/util/change_detection_utils.js +23 -0
- package/esm5/src/render3/util/discovery_utils.js +115 -99
- package/esm5/src/render3/util/global_utils.js +5 -5
- package/esm5/src/render3/util/view_utils.js +5 -5
- package/esm5/src/render3/view_engine_compatibility.js +37 -39
- package/esm5/src/render3/view_ref.js +14 -13
- package/esm5/src/sanitization/bypass.js +1 -1
- package/esm5/src/sanitization/sanitization.js +16 -5
- package/esm5/src/util/array_utils.js +240 -1
- package/esm5/src/util/assert.js +37 -21
- package/esm5/src/util/char_code.js +8 -0
- package/esm5/src/util/iterable.js +4 -1
- package/esm5/src/util/ng_dev_mode.js +1 -12
- package/esm5/src/util/stringify.js +14 -1
- package/esm5/src/version.js +1 -1
- package/esm5/src/view/services.js +1 -1
- package/esm5/testing/src/r3_test_bed.js +9 -1
- package/esm5/testing/src/r3_test_bed_compiler.js +9 -15
- package/esm5/testing/src/styling.js +82 -0
- package/fesm2015/core.js +6431 -7075
- package/fesm2015/core.js.map +1 -1
- package/fesm2015/testing.js +10 -14
- package/fesm2015/testing.js.map +1 -1
- package/fesm5/core.js +6354 -6361
- package/fesm5/core.js.map +1 -1
- package/fesm5/testing.js +18 -16
- package/fesm5/testing.js.map +1 -1
- package/package.json +1 -1
- package/src/r3_symbols.d.ts +46 -23
- package/testing/testing.d.ts +3 -5
- package/testing/testing.metadata.json +1 -1
- package/testing.d.ts +2 -2
- package/esm2015/global.js +0 -7
- package/esm2015/src/render3/instructions/alloc_host_vars.js +0 -80
- package/esm2015/src/render3/styling/bindings.js +0 -1248
- package/esm2015/src/render3/styling/map_based_bindings.js +0 -384
- package/esm2015/src/render3/styling/state.js +0 -135
- package/esm2015/src/render3/styling/styling_debug.js +0 -655
- package/esm2015/src/render3/util/styling_utils.js +0 -625
- package/esm5/global.js +0 -9
- package/esm5/src/render3/instructions/alloc_host_vars.js +0 -62
- package/esm5/src/render3/styling/bindings.js +0 -949
- package/esm5/src/render3/styling/map_based_bindings.js +0 -310
- package/esm5/src/render3/styling/state.js +0 -56
- package/esm5/src/render3/styling/styling_debug.js +0 -315
- package/esm5/src/render3/util/styling_utils.js +0 -378
|
@@ -5,13 +5,13 @@
|
|
|
5
5
|
* Use of this source code is governed by an MIT-style license that can be
|
|
6
6
|
* found in the LICENSE file at https://angular.io/license
|
|
7
7
|
*/
|
|
8
|
-
import { assertDefined
|
|
8
|
+
import { assertDefined } from '../util/assert';
|
|
9
9
|
import { assertLViewOrUndefined } from './assert';
|
|
10
10
|
import { CONTEXT, DECLARATION_VIEW, TVIEW } from './interfaces/view';
|
|
11
|
+
import { MATH_ML_NAMESPACE, SVG_NAMESPACE } from './namespaces';
|
|
11
12
|
export var instructionState = {
|
|
12
13
|
lFrame: createLFrame(null),
|
|
13
14
|
bindingsEnabled: true,
|
|
14
|
-
elementExitFn: null,
|
|
15
15
|
checkNoChangesMode: false,
|
|
16
16
|
};
|
|
17
17
|
export function getElementDepthCount() {
|
|
@@ -23,12 +23,6 @@ export function increaseElementDepthCount() {
|
|
|
23
23
|
export function decreaseElementDepthCount() {
|
|
24
24
|
instructionState.lFrame.elementDepthCount--;
|
|
25
25
|
}
|
|
26
|
-
export function getCurrentDirectiveDef() {
|
|
27
|
-
return instructionState.lFrame.currentDirectiveDef;
|
|
28
|
-
}
|
|
29
|
-
export function setCurrentDirectiveDef(def) {
|
|
30
|
-
instructionState.lFrame.currentDirectiveDef = def;
|
|
31
|
-
}
|
|
32
26
|
export function getBindingsEnabled() {
|
|
33
27
|
return instructionState.bindingsEnabled;
|
|
34
28
|
}
|
|
@@ -77,112 +71,16 @@ export function ɵɵdisableBindings() {
|
|
|
77
71
|
instructionState.bindingsEnabled = false;
|
|
78
72
|
}
|
|
79
73
|
/**
|
|
80
|
-
* Return the current LView
|
|
81
|
-
*
|
|
82
|
-
* The return value can be `null` if the method is called outside of template. This can happen if
|
|
83
|
-
* directive is instantiated by module injector (rather than by node injector.)
|
|
74
|
+
* Return the current `LView`.
|
|
84
75
|
*/
|
|
85
76
|
export function getLView() {
|
|
86
|
-
|
|
87
|
-
var lFrame = instructionState.lFrame;
|
|
88
|
-
return lFrame === null ? null : lFrame.lView;
|
|
77
|
+
return instructionState.lFrame.lView;
|
|
89
78
|
}
|
|
90
79
|
/**
|
|
91
|
-
*
|
|
80
|
+
* Return the current `TView`.
|
|
92
81
|
*/
|
|
93
|
-
export function
|
|
94
|
-
return
|
|
95
|
-
}
|
|
96
|
-
/**
|
|
97
|
-
* Sets a flag is for the active element.
|
|
98
|
-
*/
|
|
99
|
-
function setActiveElementFlag(flag) {
|
|
100
|
-
instructionState.lFrame.selectedIndex |= flag;
|
|
101
|
-
}
|
|
102
|
-
/**
|
|
103
|
-
* Sets the active directive host element and resets the directive id value
|
|
104
|
-
* (when the provided elementIndex value has changed).
|
|
105
|
-
*
|
|
106
|
-
* @param elementIndex the element index value for the host element where
|
|
107
|
-
* the directive/component instance lives
|
|
108
|
-
*/
|
|
109
|
-
export function setActiveHostElement(elementIndex) {
|
|
110
|
-
if (hasActiveElementFlag(1 /* RunExitFn */)) {
|
|
111
|
-
executeElementExitFn();
|
|
112
|
-
}
|
|
113
|
-
setSelectedIndex(elementIndex === null ? -1 : elementIndex);
|
|
114
|
-
instructionState.lFrame.activeDirectiveId = 0;
|
|
115
|
-
}
|
|
116
|
-
export function executeElementExitFn() {
|
|
117
|
-
instructionState.elementExitFn();
|
|
118
|
-
instructionState.lFrame.selectedIndex &= ~1 /* RunExitFn */;
|
|
119
|
-
}
|
|
120
|
-
/**
|
|
121
|
-
* Queues a function to be run once the element is "exited" in CD.
|
|
122
|
-
*
|
|
123
|
-
* Change detection will focus on an element either when the `advance()`
|
|
124
|
-
* instruction is called or when the template or host bindings instruction
|
|
125
|
-
* code is invoked. The element is then "exited" when the next element is
|
|
126
|
-
* selected or when change detection for the template or host bindings is
|
|
127
|
-
* complete. When this occurs (the element change operation) then an exit
|
|
128
|
-
* function will be invoked if it has been set. This function can be used
|
|
129
|
-
* to assign that exit function.
|
|
130
|
-
*
|
|
131
|
-
* @param fn
|
|
132
|
-
*/
|
|
133
|
-
export function setElementExitFn(fn) {
|
|
134
|
-
setActiveElementFlag(1 /* RunExitFn */);
|
|
135
|
-
if (instructionState.elementExitFn === null) {
|
|
136
|
-
instructionState.elementExitFn = fn;
|
|
137
|
-
}
|
|
138
|
-
ngDevMode &&
|
|
139
|
-
assertEqual(instructionState.elementExitFn, fn, 'Expecting to always get the same function');
|
|
140
|
-
}
|
|
141
|
-
/**
|
|
142
|
-
* Returns the current id value of the current directive.
|
|
143
|
-
*
|
|
144
|
-
* For example we have an element that has two directives on it:
|
|
145
|
-
* <div dir-one dir-two></div>
|
|
146
|
-
*
|
|
147
|
-
* dirOne->hostBindings() (id == 1)
|
|
148
|
-
* dirTwo->hostBindings() (id == 2)
|
|
149
|
-
*
|
|
150
|
-
* Note that this is only active when `hostBinding` functions are being processed.
|
|
151
|
-
*
|
|
152
|
-
* Note that directive id values are specific to an element (this means that
|
|
153
|
-
* the same id value could be present on another element with a completely
|
|
154
|
-
* different set of directives).
|
|
155
|
-
*/
|
|
156
|
-
export function getActiveDirectiveId() {
|
|
157
|
-
return instructionState.lFrame.activeDirectiveId;
|
|
158
|
-
}
|
|
159
|
-
/**
|
|
160
|
-
* Increments the current directive id value.
|
|
161
|
-
*
|
|
162
|
-
* For example we have an element that has two directives on it:
|
|
163
|
-
* <div dir-one dir-two></div>
|
|
164
|
-
*
|
|
165
|
-
* dirOne->hostBindings() (index = 1)
|
|
166
|
-
* // increment
|
|
167
|
-
* dirTwo->hostBindings() (index = 2)
|
|
168
|
-
*
|
|
169
|
-
* Depending on whether or not a previous directive had any inherited
|
|
170
|
-
* directives present, that value will be incremented in addition
|
|
171
|
-
* to the id jumping up by one.
|
|
172
|
-
*
|
|
173
|
-
* Note that this is only active when `hostBinding` functions are being processed.
|
|
174
|
-
*
|
|
175
|
-
* Note that directive id values are specific to an element (this means that
|
|
176
|
-
* the same id value could be present on another element with a completely
|
|
177
|
-
* different set of directives).
|
|
178
|
-
*/
|
|
179
|
-
export function incrementActiveDirectiveId() {
|
|
180
|
-
// Each directive gets a uniqueId value that is the same for both
|
|
181
|
-
// create and update calls when the hostBindings function is called. The
|
|
182
|
-
// directive uniqueId is not set anywhere--it is just incremented between
|
|
183
|
-
// each hostBindings call and is useful for helping instruction code
|
|
184
|
-
// uniquely determine which directive is currently active when executed.
|
|
185
|
-
instructionState.lFrame.activeDirectiveId += 1;
|
|
82
|
+
export function getTView() {
|
|
83
|
+
return instructionState.lFrame.tView;
|
|
186
84
|
}
|
|
187
85
|
/**
|
|
188
86
|
* Restores `contextViewData` to the given OpaqueViewState instance.
|
|
@@ -218,6 +116,7 @@ export function getContextLView() {
|
|
|
218
116
|
return instructionState.lFrame.contextLView;
|
|
219
117
|
}
|
|
220
118
|
export function getCheckNoChangesMode() {
|
|
119
|
+
// TODO(misko): remove this from the LView since it is ngDevMode=true mode only.
|
|
221
120
|
return instructionState.checkNoChangesMode;
|
|
222
121
|
}
|
|
223
122
|
export function setCheckNoChangesMode(mode) {
|
|
@@ -228,8 +127,7 @@ export function getBindingRoot() {
|
|
|
228
127
|
var lFrame = instructionState.lFrame;
|
|
229
128
|
var index = lFrame.bindingRootIndex;
|
|
230
129
|
if (index === -1) {
|
|
231
|
-
|
|
232
|
-
index = lFrame.bindingRootIndex = lView[TVIEW].bindingStartIndex;
|
|
130
|
+
index = lFrame.bindingRootIndex = lFrame.tView.bindingStartIndex;
|
|
233
131
|
}
|
|
234
132
|
return index;
|
|
235
133
|
}
|
|
@@ -254,10 +152,23 @@ export function incrementBindingIndex(count) {
|
|
|
254
152
|
* Bindings inside the host template are 0 index. But because we don't know ahead of time
|
|
255
153
|
* how many host bindings we have we can't pre-compute them. For this reason they are all
|
|
256
154
|
* 0 index and we just shift the root so that they match next available location in the LView.
|
|
257
|
-
*
|
|
155
|
+
*
|
|
156
|
+
* @param bindingRootIndex Root index for `hostBindings`
|
|
157
|
+
* @param currentDirectiveIndex `TData[currentDirectiveIndex]` will point to the current directive
|
|
158
|
+
* whose `hostBindings` are being processed.
|
|
159
|
+
*/
|
|
160
|
+
export function setBindingRootForHostBindings(bindingRootIndex, currentDirectiveIndex) {
|
|
161
|
+
var lFrame = instructionState.lFrame;
|
|
162
|
+
lFrame.bindingIndex = lFrame.bindingRootIndex = bindingRootIndex;
|
|
163
|
+
lFrame.currentDirectiveIndex = currentDirectiveIndex;
|
|
164
|
+
}
|
|
165
|
+
/**
|
|
166
|
+
* When host binding is executing this points to the directive index.
|
|
167
|
+
* `TView.data[getCurrentDirectiveIndex()]` is `DirectiveDef`
|
|
168
|
+
* `LView[getCurrentDirectiveIndex()]` is directive instance.
|
|
258
169
|
*/
|
|
259
|
-
export function
|
|
260
|
-
instructionState.lFrame.
|
|
170
|
+
export function getCurrentDirectiveIndex() {
|
|
171
|
+
return instructionState.lFrame.currentDirectiveIndex;
|
|
261
172
|
}
|
|
262
173
|
export function getCurrentQueryIndex() {
|
|
263
174
|
return instructionState.lFrame.currentQueryIndex;
|
|
@@ -284,8 +195,6 @@ export function enterDI(newView, tNode) {
|
|
|
284
195
|
newLFrame.elementDepthCount = DEV_MODE_VALUE;
|
|
285
196
|
newLFrame.currentNamespace = DEV_MODE_VALUE;
|
|
286
197
|
newLFrame.currentSanitizer = DEV_MODE_VALUE;
|
|
287
|
-
newLFrame.currentDirectiveDef = DEV_MODE_VALUE;
|
|
288
|
-
newLFrame.activeDirectiveId = DEV_MODE_VALUE;
|
|
289
198
|
newLFrame.bindingRootIndex = DEV_MODE_VALUE;
|
|
290
199
|
newLFrame.currentQueryIndex = DEV_MODE_VALUE;
|
|
291
200
|
}
|
|
@@ -312,19 +221,20 @@ export var leaveDI = leaveView;
|
|
|
312
221
|
export function enterView(newView, tNode) {
|
|
313
222
|
ngDevMode && assertLViewOrUndefined(newView);
|
|
314
223
|
var newLFrame = allocLFrame();
|
|
224
|
+
var tView = newView[TVIEW];
|
|
315
225
|
instructionState.lFrame = newLFrame;
|
|
316
226
|
newLFrame.previousOrParentTNode = tNode;
|
|
317
227
|
newLFrame.isParent = true;
|
|
318
228
|
newLFrame.lView = newView;
|
|
229
|
+
newLFrame.tView = tView;
|
|
319
230
|
newLFrame.selectedIndex = 0;
|
|
320
231
|
newLFrame.contextLView = newView;
|
|
321
232
|
newLFrame.elementDepthCount = 0;
|
|
233
|
+
newLFrame.currentDirectiveIndex = -1;
|
|
322
234
|
newLFrame.currentNamespace = null;
|
|
323
235
|
newLFrame.currentSanitizer = null;
|
|
324
|
-
newLFrame.currentDirectiveDef = null;
|
|
325
|
-
newLFrame.activeDirectiveId = 0;
|
|
326
236
|
newLFrame.bindingRootIndex = -1;
|
|
327
|
-
newLFrame.bindingIndex =
|
|
237
|
+
newLFrame.bindingIndex = tView.bindingStartIndex;
|
|
328
238
|
newLFrame.currentQueryIndex = 0;
|
|
329
239
|
}
|
|
330
240
|
/**
|
|
@@ -341,13 +251,13 @@ function createLFrame(parent) {
|
|
|
341
251
|
previousOrParentTNode: null,
|
|
342
252
|
isParent: true,
|
|
343
253
|
lView: null,
|
|
254
|
+
tView: null,
|
|
344
255
|
selectedIndex: 0,
|
|
345
256
|
contextLView: null,
|
|
346
257
|
elementDepthCount: 0,
|
|
347
258
|
currentNamespace: null,
|
|
348
259
|
currentSanitizer: null,
|
|
349
|
-
|
|
350
|
-
activeDirectiveId: 0,
|
|
260
|
+
currentDirectiveIndex: -1,
|
|
351
261
|
bindingRootIndex: -1,
|
|
352
262
|
bindingIndex: -1,
|
|
353
263
|
currentQueryIndex: 0,
|
|
@@ -357,12 +267,6 @@ function createLFrame(parent) {
|
|
|
357
267
|
parent !== null && (parent.child = lFrame); // link the new LFrame for reuse.
|
|
358
268
|
return lFrame;
|
|
359
269
|
}
|
|
360
|
-
export function leaveViewProcessExit() {
|
|
361
|
-
if (hasActiveElementFlag(1 /* RunExitFn */)) {
|
|
362
|
-
executeElementExitFn();
|
|
363
|
-
}
|
|
364
|
-
leaveView();
|
|
365
|
-
}
|
|
366
270
|
export function leaveView() {
|
|
367
271
|
instructionState.lFrame = instructionState.lFrame.parent;
|
|
368
272
|
}
|
|
@@ -380,13 +284,13 @@ function walkUpViews(nestingLevel, currentView) {
|
|
|
380
284
|
return currentView;
|
|
381
285
|
}
|
|
382
286
|
/**
|
|
383
|
-
* Gets the
|
|
287
|
+
* Gets the currently selected element index.
|
|
384
288
|
*
|
|
385
289
|
* Used with {@link property} instruction (and more in the future) to identify the index in the
|
|
386
290
|
* current `LView` to act on.
|
|
387
291
|
*/
|
|
388
292
|
export function getSelectedIndex() {
|
|
389
|
-
return instructionState.lFrame.selectedIndex
|
|
293
|
+
return instructionState.lFrame.selectedIndex;
|
|
390
294
|
}
|
|
391
295
|
/**
|
|
392
296
|
* Sets the most recent index passed to {@link select}
|
|
@@ -398,7 +302,7 @@ export function getSelectedIndex() {
|
|
|
398
302
|
* run if and when the provided `index` value is different from the current selected index value.)
|
|
399
303
|
*/
|
|
400
304
|
export function setSelectedIndex(index) {
|
|
401
|
-
instructionState.lFrame.selectedIndex = index
|
|
305
|
+
instructionState.lFrame.selectedIndex = index;
|
|
402
306
|
}
|
|
403
307
|
/**
|
|
404
308
|
* Sets the namespace used to create elements to `'http://www.w3.org/2000/svg'` in global state.
|
|
@@ -406,7 +310,7 @@ export function setSelectedIndex(index) {
|
|
|
406
310
|
* @codeGenApi
|
|
407
311
|
*/
|
|
408
312
|
export function ɵɵnamespaceSVG() {
|
|
409
|
-
instructionState.lFrame.currentNamespace =
|
|
313
|
+
instructionState.lFrame.currentNamespace = SVG_NAMESPACE;
|
|
410
314
|
}
|
|
411
315
|
/**
|
|
412
316
|
* Sets the namespace used to create elements to `'http://www.w3.org/1998/MathML/'` in global state.
|
|
@@ -414,7 +318,7 @@ export function ɵɵnamespaceSVG() {
|
|
|
414
318
|
* @codeGenApi
|
|
415
319
|
*/
|
|
416
320
|
export function ɵɵnamespaceMathML() {
|
|
417
|
-
instructionState.lFrame.currentNamespace =
|
|
321
|
+
instructionState.lFrame.currentNamespace = MATH_ML_NAMESPACE;
|
|
418
322
|
}
|
|
419
323
|
/**
|
|
420
324
|
* Sets the namespace used to create elements to `null`, which forces element creation to use
|
|
@@ -447,4 +351,4 @@ export function getCurrentStyleSanitizer() {
|
|
|
447
351
|
var lFrame = instructionState.lFrame;
|
|
448
352
|
return lFrame === null ? null : lFrame.currentSanitizer;
|
|
449
353
|
}
|
|
450
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"state.js","sourceRoot":"","sources":["../../../../../../../../../../packages/core/src/render3/state.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 */\n\nimport {StyleSanitizeFn} from '../sanitization/style_sanitizer';\nimport {assertDefined, assertEqual} from '../util/assert';\n\nimport {assertLViewOrUndefined} from './assert';\nimport {ComponentDef, DirectiveDef} from './interfaces/definition';\nimport {TNode} from './interfaces/node';\nimport {CONTEXT, DECLARATION_VIEW, LView, OpaqueViewState, TVIEW} from './interfaces/view';\n\n\n/**\n *\n */\ninterface LFrame {\n  /**\n   * Parent LFrame.\n   *\n   * This is needed when `leaveView` is called to restore the previous state.\n   */\n  parent: LFrame;\n\n  /**\n   * Child LFrame.\n   *\n   * This is used to cache existing LFrames to relieve the memory pressure.\n   */\n  child: LFrame|null;\n\n  /**\n   * State of the current view being processed.\n   *\n   * An array of nodes (text, element, container, etc), pipes, their bindings, and\n   * any local variables that need to be stored between invocations.\n   */\n  lView: LView;\n\n  /**\n   * Used to set the parent property when nodes are created and track query results.\n   *\n   * This is used in conjection with `isParent`.\n   */\n  previousOrParentTNode: TNode;\n\n  /**\n   * If `isParent` is:\n   *  - `true`: then `previousOrParentTNode` points to a parent node.\n   *  - `false`: then `previousOrParentTNode` points to previous node (sibling).\n   */\n  isParent: boolean;\n\n  /**\n   * Index of currently selected element in LView.\n   *\n   * Used by binding instructions. Updated as part of advance instruction.\n   */\n  selectedIndex: number;\n\n  /**\n   * Current pointer to the binding index.\n   */\n  bindingIndex: number;\n\n  /**\n   * The last viewData retrieved by nextContext().\n   * Allows building nextContext() and reference() calls.\n   *\n   * e.g. const inner = x().$implicit; const outer = x().$implicit;\n   */\n  contextLView: LView;\n\n  /**\n   * Store the element depth count. This is used to identify the root elements of the template\n   * so that we can then attach patch data `LView` to only those elements. We know that those\n   * are the only places where the patch data could change, this way we will save on number\n   * of places where tha patching occurs.\n   */\n  elementDepthCount: number;\n\n  /**\n   * Current namespace to be used when creating elements\n   */\n  currentNamespace: string|null;\n\n  /**\n   * Current sanitizer\n   */\n  currentSanitizer: StyleSanitizeFn|null;\n\n\n  /**\n   * Used when processing host bindings.\n   */\n  currentDirectiveDef: DirectiveDef<any>|ComponentDef<any>|null;\n\n  /**\n   * Used as the starting directive id value.\n   *\n   * All subsequent directives are incremented from this value onwards.\n   * The reason why this value is `1` instead of `0` is because the `0`\n   * value is reserved for the template.\n   */\n  activeDirectiveId: number;\n\n  /**\n   * The root index from which pure function instructions should calculate their binding\n   * indices. In component views, this is TView.bindingStartIndex. In a host binding\n   * context, this is the TView.expandoStartIndex + any dirs/hostVars before the given dir.\n   */\n  bindingRootIndex: number;\n\n  /**\n   * Current index of a View or Content Query which needs to be processed next.\n   * We iterate over the list of Queries and increment current query index at every step.\n   */\n  currentQueryIndex: number;\n}\n\n/**\n * All implicit instruction state is stored here.\n *\n * It is useful to have a single object where all of the state is stored as a mental model\n * (rather it being spread across many different variables.)\n *\n * PERF NOTE: Turns out that writing to a true global variable is slower than\n * having an intermediate object with properties.\n */\ninterface InstructionState {\n  /**\n   * Current `LFrame`\n   *\n   * `null` if we have not called `enterView`\n   */\n  lFrame: LFrame;\n\n  /**\n   * Stores whether directives should be matched to elements.\n   *\n   * When template contains `ngNonBindable` then we need to prevent the runtime from matching\n   * directives on children of that element.\n   *\n   * Example:\n   * ```\n   * <my-comp my-directive>\n   *   Should match component / directive.\n   * </my-comp>\n   * <div ngNonBindable>\n   *   <my-comp my-directive>\n   *     Should not match component / directive because we are in ngNonBindable.\n   *   </my-comp>\n   * </div>\n   * ```\n   */\n  bindingsEnabled: boolean;\n\n  /**\n   * In this mode, any changes in bindings will throw an ExpressionChangedAfterChecked error.\n   *\n   * Necessary to support ChangeDetectorRef.checkNoChanges().\n   */\n  checkNoChangesMode: boolean;\n\n  /**\n   * Function to be called when the element is exited.\n   *\n   * NOTE: The function is here for tree shakable purposes since it is only needed by styling.\n   */\n  elementExitFn: (() => void)|null;\n}\n\nexport const instructionState: InstructionState = {\n  lFrame: createLFrame(null),\n  bindingsEnabled: true,\n  elementExitFn: null,\n  checkNoChangesMode: false,\n};\n\n\nexport function getElementDepthCount() {\n  return instructionState.lFrame.elementDepthCount;\n}\n\nexport function increaseElementDepthCount() {\n  instructionState.lFrame.elementDepthCount++;\n}\n\nexport function decreaseElementDepthCount() {\n  instructionState.lFrame.elementDepthCount--;\n}\n\nexport function getCurrentDirectiveDef(): DirectiveDef<any>|ComponentDef<any>|null {\n  return instructionState.lFrame.currentDirectiveDef;\n}\n\nexport function setCurrentDirectiveDef(def: DirectiveDef<any>| ComponentDef<any>| null): void {\n  instructionState.lFrame.currentDirectiveDef = def;\n}\n\nexport function getBindingsEnabled(): boolean {\n  return instructionState.bindingsEnabled;\n}\n\n\n/**\n * Enables directive matching on elements.\n *\n *  * Example:\n * ```\n * <my-comp my-directive>\n *   Should match component / directive.\n * </my-comp>\n * <div ngNonBindable>\n *   <!-- ɵɵdisableBindings() -->\n *   <my-comp my-directive>\n *     Should not match component / directive because we are in ngNonBindable.\n *   </my-comp>\n *   <!-- ɵɵenableBindings() -->\n * </div>\n * ```\n *\n * @codeGenApi\n */\nexport function ɵɵenableBindings(): void {\n  instructionState.bindingsEnabled = true;\n}\n\n/**\n * Disables directive matching on element.\n *\n *  * Example:\n * ```\n * <my-comp my-directive>\n *   Should match component / directive.\n * </my-comp>\n * <div ngNonBindable>\n *   <!-- ɵɵdisableBindings() -->\n *   <my-comp my-directive>\n *     Should not match component / directive because we are in ngNonBindable.\n *   </my-comp>\n *   <!-- ɵɵenableBindings() -->\n * </div>\n * ```\n *\n * @codeGenApi\n */\nexport function ɵɵdisableBindings(): void {\n  instructionState.bindingsEnabled = false;\n}\n\n/**\n * Return the current LView.\n *\n * The return value can be `null` if the method is called outside of template. This can happen if\n * directive is instantiated by module injector (rather than by node injector.)\n */\nexport function getLView(): LView {\n  // TODO(misko): the return value should be `LView|null` but doing so breaks a lot of code.\n  const lFrame = instructionState.lFrame;\n  return lFrame === null ? null ! : lFrame.lView;\n}\n\n/**\n * Flags used for an active element during change detection.\n *\n * These flags are used within other instructions to inform cleanup or\n * exit operations to run when an element is being processed.\n *\n * Note that these flags are reset each time an element changes (whether it\n * happens when `advance()` is run or when change detection exits out of a template\n * function or when all host bindings are processed for an element).\n */\nexport const enum ActiveElementFlags {\n  Initial = 0b00,\n  RunExitFn = 0b01,\n  Size = 1,\n}\n\n/**\n * Determines whether or not a flag is currently set for the active element.\n */\nexport function hasActiveElementFlag(flag: ActiveElementFlags) {\n  return (instructionState.lFrame.selectedIndex & flag) === flag;\n}\n\n/**\n * Sets a flag is for the active element.\n */\nfunction setActiveElementFlag(flag: ActiveElementFlags) {\n  instructionState.lFrame.selectedIndex |= flag;\n}\n\n/**\n * Sets the active directive host element and resets the directive id value\n * (when the provided elementIndex value has changed).\n *\n * @param elementIndex the element index value for the host element where\n *                     the directive/component instance lives\n */\nexport function setActiveHostElement(elementIndex: number | null) {\n  if (hasActiveElementFlag(ActiveElementFlags.RunExitFn)) {\n    executeElementExitFn();\n  }\n  setSelectedIndex(elementIndex === null ? -1 : elementIndex);\n  instructionState.lFrame.activeDirectiveId = 0;\n}\n\nexport function executeElementExitFn() {\n  instructionState.elementExitFn !();\n  instructionState.lFrame.selectedIndex &= ~ActiveElementFlags.RunExitFn;\n}\n\n/**\n * Queues a function to be run once the element is \"exited\" in CD.\n *\n * Change detection will focus on an element either when the `advance()`\n * instruction is called or when the template or host bindings instruction\n * code is invoked. The element is then \"exited\" when the next element is\n * selected or when change detection for the template or host bindings is\n * complete. When this occurs (the element change operation) then an exit\n * function will be invoked if it has been set. This function can be used\n * to assign that exit function.\n *\n * @param fn\n */\nexport function setElementExitFn(fn: () => void): void {\n  setActiveElementFlag(ActiveElementFlags.RunExitFn);\n  if (instructionState.elementExitFn === null) {\n    instructionState.elementExitFn = fn;\n  }\n  ngDevMode &&\n      assertEqual(instructionState.elementExitFn, fn, 'Expecting to always get the same function');\n}\n\n/**\n * Returns the current id value of the current directive.\n *\n * For example we have an element that has two directives on it:\n * <div dir-one dir-two></div>\n *\n * dirOne->hostBindings() (id == 1)\n * dirTwo->hostBindings() (id == 2)\n *\n * Note that this is only active when `hostBinding` functions are being processed.\n *\n * Note that directive id values are specific to an element (this means that\n * the same id value could be present on another element with a completely\n * different set of directives).\n */\nexport function getActiveDirectiveId() {\n  return instructionState.lFrame.activeDirectiveId;\n}\n\n/**\n * Increments the current directive id value.\n *\n * For example we have an element that has two directives on it:\n * <div dir-one dir-two></div>\n *\n * dirOne->hostBindings() (index = 1)\n * // increment\n * dirTwo->hostBindings() (index = 2)\n *\n * Depending on whether or not a previous directive had any inherited\n * directives present, that value will be incremented in addition\n * to the id jumping up by one.\n *\n * Note that this is only active when `hostBinding` functions are being processed.\n *\n * Note that directive id values are specific to an element (this means that\n * the same id value could be present on another element with a completely\n * different set of directives).\n */\nexport function incrementActiveDirectiveId() {\n  // Each directive gets a uniqueId value that is the same for both\n  // create and update calls when the hostBindings function is called. The\n  // directive uniqueId is not set anywhere--it is just incremented between\n  // each hostBindings call and is useful for helping instruction code\n  // uniquely determine which directive is currently active when executed.\n  instructionState.lFrame.activeDirectiveId += 1;\n}\n\n/**\n * Restores `contextViewData` to the given OpaqueViewState instance.\n *\n * Used in conjunction with the getCurrentView() instruction to save a snapshot\n * of the current view and restore it when listeners are invoked. This allows\n * walking the declaration view tree in listeners to get vars from parent views.\n *\n * @param viewToRestore The OpaqueViewState instance to restore.\n *\n * @codeGenApi\n */\nexport function ɵɵrestoreView(viewToRestore: OpaqueViewState) {\n  instructionState.lFrame.contextLView = viewToRestore as any as LView;\n}\n\nexport function getPreviousOrParentTNode(): TNode {\n  return instructionState.lFrame.previousOrParentTNode;\n}\n\nexport function setPreviousOrParentTNode(tNode: TNode, _isParent: boolean) {\n  instructionState.lFrame.previousOrParentTNode = tNode;\n  instructionState.lFrame.isParent = _isParent;\n}\n\nexport function getIsParent(): boolean {\n  return instructionState.lFrame.isParent;\n}\n\nexport function setIsNotParent(): void {\n  instructionState.lFrame.isParent = false;\n}\nexport function setIsParent(): void {\n  instructionState.lFrame.isParent = true;\n}\n\nexport function getContextLView(): LView {\n  return instructionState.lFrame.contextLView;\n}\n\nexport function getCheckNoChangesMode(): boolean {\n  return instructionState.checkNoChangesMode;\n}\n\nexport function setCheckNoChangesMode(mode: boolean): void {\n  instructionState.checkNoChangesMode = mode;\n}\n\n// top level variables should not be exported for performance reasons (PERF_NOTES.md)\nexport function getBindingRoot() {\n  const lFrame = instructionState.lFrame;\n  let index = lFrame.bindingRootIndex;\n  if (index === -1) {\n    const lView = lFrame.lView;\n    index = lFrame.bindingRootIndex = lView[TVIEW].bindingStartIndex;\n  }\n  return index;\n}\n\nexport function getBindingIndex(): number {\n  return instructionState.lFrame.bindingIndex;\n}\n\nexport function setBindingIndex(value: number): number {\n  return instructionState.lFrame.bindingIndex = value;\n}\n\nexport function nextBindingIndex(): number {\n  return instructionState.lFrame.bindingIndex++;\n}\n\nexport function incrementBindingIndex(count: number): number {\n  const lFrame = instructionState.lFrame;\n  const index = lFrame.bindingIndex;\n  lFrame.bindingIndex = lFrame.bindingIndex + count;\n  return index;\n}\n\n/**\n * Set a new binding root index so that host template functions can execute.\n *\n * Bindings inside the host template are 0 index. But because we don't know ahead of time\n * how many host bindings we have we can't pre-compute them. For this reason they are all\n * 0 index and we just shift the root so that they match next available location in the LView.\n * @param value\n */\nexport function setBindingRoot(value: number) {\n  instructionState.lFrame.bindingRootIndex = value;\n}\n\nexport function getCurrentQueryIndex(): number {\n  return instructionState.lFrame.currentQueryIndex;\n}\n\nexport function setCurrentQueryIndex(value: number): void {\n  instructionState.lFrame.currentQueryIndex = value;\n}\n\n/**\n * This is a light weight version of the `enterView` which is needed by the DI system.\n * @param newView\n * @param tNode\n */\nexport function enterDI(newView: LView, tNode: TNode) {\n  ngDevMode && assertLViewOrUndefined(newView);\n  const newLFrame = allocLFrame();\n  instructionState.lFrame = newLFrame;\n  newLFrame.previousOrParentTNode = tNode !;\n  newLFrame.lView = newView;\n  if (ngDevMode) {\n    // resetting for safety in dev mode only.\n    newLFrame.isParent = DEV_MODE_VALUE;\n    newLFrame.selectedIndex = DEV_MODE_VALUE;\n    newLFrame.contextLView = DEV_MODE_VALUE;\n    newLFrame.elementDepthCount = DEV_MODE_VALUE;\n    newLFrame.currentNamespace = DEV_MODE_VALUE;\n    newLFrame.currentSanitizer = DEV_MODE_VALUE;\n    newLFrame.currentDirectiveDef = DEV_MODE_VALUE;\n    newLFrame.activeDirectiveId = DEV_MODE_VALUE;\n    newLFrame.bindingRootIndex = DEV_MODE_VALUE;\n    newLFrame.currentQueryIndex = DEV_MODE_VALUE;\n  }\n}\n\nconst DEV_MODE_VALUE: any =\n    'Value indicating that DI is trying to read value which it should not need to know about.';\n\n/**\n * This is a light weight version of the `leaveView` which is needed by the DI system.\n *\n * Because the implementation is same it is only an alias\n */\nexport const leaveDI = leaveView;\n\n/**\n * Swap the current lView with a new lView.\n *\n * For performance reasons we store the lView in the top level of the module.\n * This way we minimize the number of properties to read. Whenever a new view\n * is entered we have to store the lView for later, and when the view is\n * exited the state has to be restored\n *\n * @param newView New lView to become active\n * @param tNode Element to which the View is a child of\n * @returns the previously active lView;\n */\nexport function enterView(newView: LView, tNode: TNode | null): void {\n  ngDevMode && assertLViewOrUndefined(newView);\n  const newLFrame = allocLFrame();\n  instructionState.lFrame = newLFrame;\n  newLFrame.previousOrParentTNode = tNode !;\n  newLFrame.isParent = true;\n  newLFrame.lView = newView;\n  newLFrame.selectedIndex = 0;\n  newLFrame.contextLView = newView !;\n  newLFrame.elementDepthCount = 0;\n  newLFrame.currentNamespace = null;\n  newLFrame.currentSanitizer = null;\n  newLFrame.currentDirectiveDef = null;\n  newLFrame.activeDirectiveId = 0;\n  newLFrame.bindingRootIndex = -1;\n  newLFrame.bindingIndex = newView === null ? -1 : newView[TVIEW].bindingStartIndex;\n  newLFrame.currentQueryIndex = 0;\n}\n\n/**\n * Allocates next free LFrame. This function tries to reuse the `LFrame`s to lower memory pressure.\n */\nfunction allocLFrame() {\n  const currentLFrame = instructionState.lFrame;\n  const childLFrame = currentLFrame === null ? null : currentLFrame.child;\n  const newLFrame = childLFrame === null ? createLFrame(currentLFrame) : childLFrame;\n  return newLFrame;\n}\n\nfunction createLFrame(parent: LFrame | null): LFrame {\n  const lFrame: LFrame = {\n    previousOrParentTNode: null !,  //\n    isParent: true,                 //\n    lView: null !,                  //\n    selectedIndex: 0,               //\n    contextLView: null !,           //\n    elementDepthCount: 0,           //\n    currentNamespace: null,         //\n    currentSanitizer: null,         //\n    currentDirectiveDef: null,      //\n    activeDirectiveId: 0,           //\n    bindingRootIndex: -1,           //\n    bindingIndex: -1,               //\n    currentQueryIndex: 0,           //\n    parent: parent !,               //\n    child: null,                    //\n  };\n  parent !== null && (parent.child = lFrame);  // link the new LFrame for reuse.\n  return lFrame;\n}\n\nexport function leaveViewProcessExit() {\n  if (hasActiveElementFlag(ActiveElementFlags.RunExitFn)) {\n    executeElementExitFn();\n  }\n  leaveView();\n}\n\nexport function leaveView() {\n  instructionState.lFrame = instructionState.lFrame.parent;\n}\n\nexport function nextContextImpl<T = any>(level: number): T {\n  const contextLView = instructionState.lFrame.contextLView =\n      walkUpViews(level, instructionState.lFrame.contextLView !);\n  return contextLView[CONTEXT] as T;\n}\n\nfunction walkUpViews(nestingLevel: number, currentView: LView): LView {\n  while (nestingLevel > 0) {\n    ngDevMode && assertDefined(\n                     currentView[DECLARATION_VIEW],\n                     'Declaration view should be defined if nesting level is greater than 0.');\n    currentView = currentView[DECLARATION_VIEW] !;\n    nestingLevel--;\n  }\n  return currentView;\n}\n\n/**\n * Gets the most recent index passed to {@link select}\n *\n * Used with {@link property} instruction (and more in the future) to identify the index in the\n * current `LView` to act on.\n */\nexport function getSelectedIndex() {\n  return instructionState.lFrame.selectedIndex >> ActiveElementFlags.Size;\n}\n\n/**\n * Sets the most recent index passed to {@link select}\n *\n * Used with {@link property} instruction (and more in the future) to identify the index in the\n * current `LView` to act on.\n *\n * (Note that if an \"exit function\" was set earlier (via `setElementExitFn()`) then that will be\n * run if and when the provided `index` value is different from the current selected index value.)\n */\nexport function setSelectedIndex(index: number) {\n  instructionState.lFrame.selectedIndex = index << ActiveElementFlags.Size;\n}\n\n\n/**\n * Sets the namespace used to create elements to `'http://www.w3.org/2000/svg'` in global state.\n *\n * @codeGenApi\n */\nexport function ɵɵnamespaceSVG() {\n  instructionState.lFrame.currentNamespace = 'http://www.w3.org/2000/svg';\n}\n\n/**\n * Sets the namespace used to create elements to `'http://www.w3.org/1998/MathML/'` in global state.\n *\n * @codeGenApi\n */\nexport function ɵɵnamespaceMathML() {\n  instructionState.lFrame.currentNamespace = 'http://www.w3.org/1998/MathML/';\n}\n\n/**\n * Sets the namespace used to create elements to `null`, which forces element creation to use\n * `createElement` rather than `createElementNS`.\n *\n * @codeGenApi\n */\nexport function ɵɵnamespaceHTML() {\n  namespaceHTMLInternal();\n}\n\n/**\n * Sets the namespace used to create elements to `null`, which forces element creation to use\n * `createElement` rather than `createElementNS`.\n */\nexport function namespaceHTMLInternal() {\n  instructionState.lFrame.currentNamespace = null;\n}\n\nexport function getNamespace(): string|null {\n  return instructionState.lFrame.currentNamespace;\n}\n\nexport function setCurrentStyleSanitizer(sanitizer: StyleSanitizeFn | null) {\n  instructionState.lFrame.currentSanitizer = sanitizer;\n}\n\nexport function resetCurrentStyleSanitizer() {\n  setCurrentStyleSanitizer(null);\n}\n\nexport function getCurrentStyleSanitizer() {\n  // TODO(misko): This should throw when there is no LView, but it turns out we can get here from\n  // `NodeStyleDebug` hence we return `null`. This should be fixed\n  const lFrame = instructionState.lFrame;\n  return lFrame === null ? null : lFrame.currentSanitizer;\n}\n"]}
|
|
354
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"state.js","sourceRoot":"","sources":["../../../../../../../../../../packages/core/src/render3/state.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 */\n\nimport {StyleSanitizeFn} from '../sanitization/style_sanitizer';\nimport {assertDefined} from '../util/assert';\nimport {assertLViewOrUndefined} from './assert';\nimport {TNode} from './interfaces/node';\nimport {CONTEXT, DECLARATION_VIEW, LView, OpaqueViewState, TVIEW, TView} from './interfaces/view';\nimport {MATH_ML_NAMESPACE, SVG_NAMESPACE} from './namespaces';\n\n\n/**\n *\n */\ninterface LFrame {\n  /**\n   * Parent LFrame.\n   *\n   * This is needed when `leaveView` is called to restore the previous state.\n   */\n  parent: LFrame;\n\n  /**\n   * Child LFrame.\n   *\n   * This is used to cache existing LFrames to relieve the memory pressure.\n   */\n  child: LFrame|null;\n\n  /**\n   * State of the current view being processed.\n   *\n   * An array of nodes (text, element, container, etc), pipes, their bindings, and\n   * any local variables that need to be stored between invocations.\n   */\n  lView: LView;\n\n  /**\n   * Current `TView` associated with the `LFrame.lView`.\n   *\n   * One can get `TView` from `lFrame[TVIEW]` however because it is so common it makes sense to\n   * store it in `LFrame` for perf reasons.\n   */\n  tView: TView;\n\n  /**\n   * Used to set the parent property when nodes are created and track query results.\n   *\n   * This is used in conjunction with `isParent`.\n   */\n  previousOrParentTNode: TNode;\n\n  /**\n   * If `isParent` is:\n   *  - `true`: then `previousOrParentTNode` points to a parent node.\n   *  - `false`: then `previousOrParentTNode` points to previous node (sibling).\n   */\n  isParent: boolean;\n\n  /**\n   * Index of currently selected element in LView.\n   *\n   * Used by binding instructions. Updated as part of advance instruction.\n   */\n  selectedIndex: number;\n\n  /**\n   * Current pointer to the binding index.\n   */\n  bindingIndex: number;\n\n  /**\n   * The last viewData retrieved by nextContext().\n   * Allows building nextContext() and reference() calls.\n   *\n   * e.g. const inner = x().$implicit; const outer = x().$implicit;\n   */\n  contextLView: LView;\n\n  /**\n   * Store the element depth count. This is used to identify the root elements of the template\n   * so that we can then attach patch data `LView` to only those elements. We know that those\n   * are the only places where the patch data could change, this way we will save on number\n   * of places where tha patching occurs.\n   */\n  elementDepthCount: number;\n\n  /**\n   * Current namespace to be used when creating elements\n   */\n  currentNamespace: string|null;\n\n  /**\n   * Current sanitizer\n   */\n  currentSanitizer: StyleSanitizeFn|null;\n\n\n  /**\n   * The root index from which pure function instructions should calculate their binding\n   * indices. In component views, this is TView.bindingStartIndex. In a host binding\n   * context, this is the TView.expandoStartIndex + any dirs/hostVars before the given dir.\n   */\n  bindingRootIndex: number;\n\n  /**\n   * Current index of a View or Content Query which needs to be processed next.\n   * We iterate over the list of Queries and increment current query index at every step.\n   */\n  currentQueryIndex: number;\n\n  /**\n   * When host binding is executing this points to the directive index.\n   * `TView.data[currentDirectiveIndex]` is `DirectiveDef`\n   * `LView[currentDirectiveIndex]` is directive instance.\n   */\n  currentDirectiveIndex: number;\n}\n\n/**\n * All implicit instruction state is stored here.\n *\n * It is useful to have a single object where all of the state is stored as a mental model\n * (rather it being spread across many different variables.)\n *\n * PERF NOTE: Turns out that writing to a true global variable is slower than\n * having an intermediate object with properties.\n */\ninterface InstructionState {\n  /**\n   * Current `LFrame`\n   *\n   * `null` if we have not called `enterView`\n   */\n  lFrame: LFrame;\n\n  /**\n   * Stores whether directives should be matched to elements.\n   *\n   * When template contains `ngNonBindable` then we need to prevent the runtime from matching\n   * directives on children of that element.\n   *\n   * Example:\n   * ```\n   * <my-comp my-directive>\n   *   Should match component / directive.\n   * </my-comp>\n   * <div ngNonBindable>\n   *   <my-comp my-directive>\n   *     Should not match component / directive because we are in ngNonBindable.\n   *   </my-comp>\n   * </div>\n   * ```\n   */\n  bindingsEnabled: boolean;\n\n  /**\n   * In this mode, any changes in bindings will throw an ExpressionChangedAfterChecked error.\n   *\n   * Necessary to support ChangeDetectorRef.checkNoChanges().\n   */\n  checkNoChangesMode: boolean;\n}\n\nexport const instructionState: InstructionState = {\n  lFrame: createLFrame(null),\n  bindingsEnabled: true,\n  checkNoChangesMode: false,\n};\n\n\nexport function getElementDepthCount() {\n  return instructionState.lFrame.elementDepthCount;\n}\n\nexport function increaseElementDepthCount() {\n  instructionState.lFrame.elementDepthCount++;\n}\n\nexport function decreaseElementDepthCount() {\n  instructionState.lFrame.elementDepthCount--;\n}\n\nexport function getBindingsEnabled(): boolean {\n  return instructionState.bindingsEnabled;\n}\n\n\n/**\n * Enables directive matching on elements.\n *\n *  * Example:\n * ```\n * <my-comp my-directive>\n *   Should match component / directive.\n * </my-comp>\n * <div ngNonBindable>\n *   <!-- ɵɵdisableBindings() -->\n *   <my-comp my-directive>\n *     Should not match component / directive because we are in ngNonBindable.\n *   </my-comp>\n *   <!-- ɵɵenableBindings() -->\n * </div>\n * ```\n *\n * @codeGenApi\n */\nexport function ɵɵenableBindings(): void {\n  instructionState.bindingsEnabled = true;\n}\n\n/**\n * Disables directive matching on element.\n *\n *  * Example:\n * ```\n * <my-comp my-directive>\n *   Should match component / directive.\n * </my-comp>\n * <div ngNonBindable>\n *   <!-- ɵɵdisableBindings() -->\n *   <my-comp my-directive>\n *     Should not match component / directive because we are in ngNonBindable.\n *   </my-comp>\n *   <!-- ɵɵenableBindings() -->\n * </div>\n * ```\n *\n * @codeGenApi\n */\nexport function ɵɵdisableBindings(): void {\n  instructionState.bindingsEnabled = false;\n}\n\n/**\n * Return the current `LView`.\n */\nexport function getLView(): LView {\n  return instructionState.lFrame.lView;\n}\n\n/**\n * Return the current `TView`.\n */\nexport function getTView(): TView {\n  return instructionState.lFrame.tView;\n}\n\n/**\n * Restores `contextViewData` to the given OpaqueViewState instance.\n *\n * Used in conjunction with the getCurrentView() instruction to save a snapshot\n * of the current view and restore it when listeners are invoked. This allows\n * walking the declaration view tree in listeners to get vars from parent views.\n *\n * @param viewToRestore The OpaqueViewState instance to restore.\n *\n * @codeGenApi\n */\nexport function ɵɵrestoreView(viewToRestore: OpaqueViewState) {\n  instructionState.lFrame.contextLView = viewToRestore as any as LView;\n}\n\nexport function getPreviousOrParentTNode(): TNode {\n  return instructionState.lFrame.previousOrParentTNode;\n}\n\nexport function setPreviousOrParentTNode(tNode: TNode, _isParent: boolean) {\n  instructionState.lFrame.previousOrParentTNode = tNode;\n  instructionState.lFrame.isParent = _isParent;\n}\n\nexport function getIsParent(): boolean {\n  return instructionState.lFrame.isParent;\n}\n\nexport function setIsNotParent(): void {\n  instructionState.lFrame.isParent = false;\n}\nexport function setIsParent(): void {\n  instructionState.lFrame.isParent = true;\n}\n\nexport function getContextLView(): LView {\n  return instructionState.lFrame.contextLView;\n}\n\nexport function getCheckNoChangesMode(): boolean {\n  // TODO(misko): remove this from the LView since it is ngDevMode=true mode only.\n  return instructionState.checkNoChangesMode;\n}\n\nexport function setCheckNoChangesMode(mode: boolean): void {\n  instructionState.checkNoChangesMode = mode;\n}\n\n// top level variables should not be exported for performance reasons (PERF_NOTES.md)\nexport function getBindingRoot() {\n  const lFrame = instructionState.lFrame;\n  let index = lFrame.bindingRootIndex;\n  if (index === -1) {\n    index = lFrame.bindingRootIndex = lFrame.tView.bindingStartIndex;\n  }\n  return index;\n}\n\nexport function getBindingIndex(): number {\n  return instructionState.lFrame.bindingIndex;\n}\n\nexport function setBindingIndex(value: number): number {\n  return instructionState.lFrame.bindingIndex = value;\n}\n\nexport function nextBindingIndex(): number {\n  return instructionState.lFrame.bindingIndex++;\n}\n\nexport function incrementBindingIndex(count: number): number {\n  const lFrame = instructionState.lFrame;\n  const index = lFrame.bindingIndex;\n  lFrame.bindingIndex = lFrame.bindingIndex + count;\n  return index;\n}\n\n/**\n * Set a new binding root index so that host template functions can execute.\n *\n * Bindings inside the host template are 0 index. But because we don't know ahead of time\n * how many host bindings we have we can't pre-compute them. For this reason they are all\n * 0 index and we just shift the root so that they match next available location in the LView.\n *\n * @param bindingRootIndex Root index for `hostBindings`\n * @param currentDirectiveIndex `TData[currentDirectiveIndex]` will point to the current directive\n *        whose `hostBindings` are being processed.\n */\nexport function setBindingRootForHostBindings(\n    bindingRootIndex: number, currentDirectiveIndex: number) {\n  const lFrame = instructionState.lFrame;\n  lFrame.bindingIndex = lFrame.bindingRootIndex = bindingRootIndex;\n  lFrame.currentDirectiveIndex = currentDirectiveIndex;\n}\n\n/**\n * When host binding is executing this points to the directive index.\n * `TView.data[getCurrentDirectiveIndex()]` is `DirectiveDef`\n * `LView[getCurrentDirectiveIndex()]` is directive instance.\n */\nexport function getCurrentDirectiveIndex(): number {\n  return instructionState.lFrame.currentDirectiveIndex;\n}\n\nexport function getCurrentQueryIndex(): number {\n  return instructionState.lFrame.currentQueryIndex;\n}\n\nexport function setCurrentQueryIndex(value: number): void {\n  instructionState.lFrame.currentQueryIndex = value;\n}\n\n/**\n * This is a light weight version of the `enterView` which is needed by the DI system.\n * @param newView\n * @param tNode\n */\nexport function enterDI(newView: LView, tNode: TNode) {\n  ngDevMode && assertLViewOrUndefined(newView);\n  const newLFrame = allocLFrame();\n  instructionState.lFrame = newLFrame;\n  newLFrame.previousOrParentTNode = tNode !;\n  newLFrame.lView = newView;\n  if (ngDevMode) {\n    // resetting for safety in dev mode only.\n    newLFrame.isParent = DEV_MODE_VALUE;\n    newLFrame.selectedIndex = DEV_MODE_VALUE;\n    newLFrame.contextLView = DEV_MODE_VALUE;\n    newLFrame.elementDepthCount = DEV_MODE_VALUE;\n    newLFrame.currentNamespace = DEV_MODE_VALUE;\n    newLFrame.currentSanitizer = DEV_MODE_VALUE;\n    newLFrame.bindingRootIndex = DEV_MODE_VALUE;\n    newLFrame.currentQueryIndex = DEV_MODE_VALUE;\n  }\n}\n\nconst DEV_MODE_VALUE: any =\n    'Value indicating that DI is trying to read value which it should not need to know about.';\n\n/**\n * This is a light weight version of the `leaveView` which is needed by the DI system.\n *\n * Because the implementation is same it is only an alias\n */\nexport const leaveDI = leaveView;\n\n/**\n * Swap the current lView with a new lView.\n *\n * For performance reasons we store the lView in the top level of the module.\n * This way we minimize the number of properties to read. Whenever a new view\n * is entered we have to store the lView for later, and when the view is\n * exited the state has to be restored\n *\n * @param newView New lView to become active\n * @param tNode Element to which the View is a child of\n * @returns the previously active lView;\n */\nexport function enterView(newView: LView, tNode: TNode | null): void {\n  ngDevMode && assertLViewOrUndefined(newView);\n  const newLFrame = allocLFrame();\n  const tView = newView[TVIEW];\n  instructionState.lFrame = newLFrame;\n  newLFrame.previousOrParentTNode = tNode !;\n  newLFrame.isParent = true;\n  newLFrame.lView = newView;\n  newLFrame.tView = tView;\n  newLFrame.selectedIndex = 0;\n  newLFrame.contextLView = newView !;\n  newLFrame.elementDepthCount = 0;\n  newLFrame.currentDirectiveIndex = -1;\n  newLFrame.currentNamespace = null;\n  newLFrame.currentSanitizer = null;\n  newLFrame.bindingRootIndex = -1;\n  newLFrame.bindingIndex = tView.bindingStartIndex;\n  newLFrame.currentQueryIndex = 0;\n}\n\n/**\n * Allocates next free LFrame. This function tries to reuse the `LFrame`s to lower memory pressure.\n */\nfunction allocLFrame() {\n  const currentLFrame = instructionState.lFrame;\n  const childLFrame = currentLFrame === null ? null : currentLFrame.child;\n  const newLFrame = childLFrame === null ? createLFrame(currentLFrame) : childLFrame;\n  return newLFrame;\n}\n\nfunction createLFrame(parent: LFrame | null): LFrame {\n  const lFrame: LFrame = {\n    previousOrParentTNode: null !,  //\n    isParent: true,                 //\n    lView: null !,                  //\n    tView: null !,                  //\n    selectedIndex: 0,               //\n    contextLView: null !,           //\n    elementDepthCount: 0,           //\n    currentNamespace: null,         //\n    currentSanitizer: null,         //\n    currentDirectiveIndex: -1,      //\n    bindingRootIndex: -1,           //\n    bindingIndex: -1,               //\n    currentQueryIndex: 0,           //\n    parent: parent !,               //\n    child: null,                    //\n  };\n  parent !== null && (parent.child = lFrame);  // link the new LFrame for reuse.\n  return lFrame;\n}\n\nexport function leaveView() {\n  instructionState.lFrame = instructionState.lFrame.parent;\n}\n\nexport function nextContextImpl<T = any>(level: number): T {\n  const contextLView = instructionState.lFrame.contextLView =\n      walkUpViews(level, instructionState.lFrame.contextLView !);\n  return contextLView[CONTEXT] as T;\n}\n\nfunction walkUpViews(nestingLevel: number, currentView: LView): LView {\n  while (nestingLevel > 0) {\n    ngDevMode && assertDefined(\n                     currentView[DECLARATION_VIEW],\n                     'Declaration view should be defined if nesting level is greater than 0.');\n    currentView = currentView[DECLARATION_VIEW] !;\n    nestingLevel--;\n  }\n  return currentView;\n}\n\n/**\n * Gets the currently selected element index.\n *\n * Used with {@link property} instruction (and more in the future) to identify the index in the\n * current `LView` to act on.\n */\nexport function getSelectedIndex() {\n  return instructionState.lFrame.selectedIndex;\n}\n\n/**\n * Sets the most recent index passed to {@link select}\n *\n * Used with {@link property} instruction (and more in the future) to identify the index in the\n * current `LView` to act on.\n *\n * (Note that if an \"exit function\" was set earlier (via `setElementExitFn()`) then that will be\n * run if and when the provided `index` value is different from the current selected index value.)\n */\nexport function setSelectedIndex(index: number) {\n  instructionState.lFrame.selectedIndex = index;\n}\n\n\n/**\n * Sets the namespace used to create elements to `'http://www.w3.org/2000/svg'` in global state.\n *\n * @codeGenApi\n */\nexport function ɵɵnamespaceSVG() {\n  instructionState.lFrame.currentNamespace = SVG_NAMESPACE;\n}\n\n/**\n * Sets the namespace used to create elements to `'http://www.w3.org/1998/MathML/'` in global state.\n *\n * @codeGenApi\n */\nexport function ɵɵnamespaceMathML() {\n  instructionState.lFrame.currentNamespace = MATH_ML_NAMESPACE;\n}\n\n/**\n * Sets the namespace used to create elements to `null`, which forces element creation to use\n * `createElement` rather than `createElementNS`.\n *\n * @codeGenApi\n */\nexport function ɵɵnamespaceHTML() {\n  namespaceHTMLInternal();\n}\n\n/**\n * Sets the namespace used to create elements to `null`, which forces element creation to use\n * `createElement` rather than `createElementNS`.\n */\nexport function namespaceHTMLInternal() {\n  instructionState.lFrame.currentNamespace = null;\n}\n\nexport function getNamespace(): string|null {\n  return instructionState.lFrame.currentNamespace;\n}\n\nexport function setCurrentStyleSanitizer(sanitizer: StyleSanitizeFn | null) {\n  instructionState.lFrame.currentSanitizer = sanitizer;\n}\n\nexport function resetCurrentStyleSanitizer() {\n  setCurrentStyleSanitizer(null);\n}\n\nexport function getCurrentStyleSanitizer() {\n  // TODO(misko): This should throw when there is no LView, but it turns out we can get here from\n  // `NodeStyleDebug` hence we return `null`. This should be fixed\n  const lFrame = instructionState.lFrame;\n  return lFrame === null ? null : lFrame.currentSanitizer;\n}\n"]}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright Google Inc. All Rights Reserved.
|
|
4
|
+
*
|
|
5
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
+
* found in the LICENSE file at https://angular.io/license
|
|
7
|
+
*/
|
|
8
|
+
import { assertNotEqual } from '../../util/assert';
|
|
9
|
+
/**
|
|
10
|
+
* Returns an index of `classToSearch` in `className` taking token boundaries into account.
|
|
11
|
+
*
|
|
12
|
+
* `classIndexOf('AB A', 'A', 0)` will be 3 (not 0 since `AB!==A`)
|
|
13
|
+
*
|
|
14
|
+
* @param className A string containing classes (whitespace separated)
|
|
15
|
+
* @param classToSearch A class name to locate
|
|
16
|
+
* @param startingIndex Starting location of search
|
|
17
|
+
* @returns an index of the located class (or -1 if not found)
|
|
18
|
+
*/
|
|
19
|
+
export function classIndexOf(className, classToSearch, startingIndex) {
|
|
20
|
+
ngDevMode && assertNotEqual(classToSearch, '', 'can not look for "" string.');
|
|
21
|
+
var end = className.length;
|
|
22
|
+
while (true) {
|
|
23
|
+
var foundIndex = className.indexOf(classToSearch, startingIndex);
|
|
24
|
+
if (foundIndex === -1)
|
|
25
|
+
return foundIndex;
|
|
26
|
+
if (foundIndex === 0 || className.charCodeAt(foundIndex - 1) <= 32 /* SPACE */) {
|
|
27
|
+
// Ensure that it has leading whitespace
|
|
28
|
+
var length_1 = classToSearch.length;
|
|
29
|
+
if (foundIndex + length_1 === end ||
|
|
30
|
+
className.charCodeAt(foundIndex + length_1) <= 32 /* SPACE */) {
|
|
31
|
+
// Ensure that it has trailing whitespace
|
|
32
|
+
return foundIndex;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
// False positive, keep searching from where we left off.
|
|
36
|
+
startingIndex = foundIndex + 1;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xhc3NfZGlmZmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29yZS9zcmMvcmVuZGVyMy9zdHlsaW5nL2NsYXNzX2RpZmZlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0VBTUU7QUFFRixPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sbUJBQW1CLENBQUM7QUFJakQ7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBTSxVQUFVLFlBQVksQ0FDeEIsU0FBaUIsRUFBRSxhQUFxQixFQUFFLGFBQXFCO0lBQ2pFLFNBQVMsSUFBSSxjQUFjLENBQUMsYUFBYSxFQUFFLEVBQUUsRUFBRSw2QkFBNkIsQ0FBQyxDQUFDO0lBQzlFLElBQUksR0FBRyxHQUFHLFNBQVMsQ0FBQyxNQUFNLENBQUM7SUFDM0IsT0FBTyxJQUFJLEVBQUU7UUFDWCxJQUFNLFVBQVUsR0FBRyxTQUFTLENBQUMsT0FBTyxDQUFDLGFBQWEsRUFBRSxhQUFhLENBQUMsQ0FBQztRQUNuRSxJQUFJLFVBQVUsS0FBSyxDQUFDLENBQUM7WUFBRSxPQUFPLFVBQVUsQ0FBQztRQUN6QyxJQUFJLFVBQVUsS0FBSyxDQUFDLElBQUksU0FBUyxDQUFDLFVBQVUsQ0FBQyxVQUFVLEdBQUcsQ0FBQyxDQUFDLGtCQUFrQixFQUFFO1lBQzlFLHdDQUF3QztZQUN4QyxJQUFNLFFBQU0sR0FBRyxhQUFhLENBQUMsTUFBTSxDQUFDO1lBQ3BDLElBQUksVUFBVSxHQUFHLFFBQU0sS0FBSyxHQUFHO2dCQUMzQixTQUFTLENBQUMsVUFBVSxDQUFDLFVBQVUsR0FBRyxRQUFNLENBQUMsa0JBQWtCLEVBQUU7Z0JBQy9ELHlDQUF5QztnQkFDekMsT0FBTyxVQUFVLENBQUM7YUFDbkI7U0FDRjtRQUNELHlEQUF5RDtRQUN6RCxhQUFhLEdBQUcsVUFBVSxHQUFHLENBQUMsQ0FBQztLQUNoQztBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiogQGxpY2Vuc2VcbiogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4qXG4qIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4qIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiovXG5cbmltcG9ydCB7YXNzZXJ0Tm90RXF1YWx9IGZyb20gJy4uLy4uL3V0aWwvYXNzZXJ0JztcbmltcG9ydCB7Q2hhckNvZGV9IGZyb20gJy4uLy4uL3V0aWwvY2hhcl9jb2RlJztcblxuXG4vKipcbiAqIFJldHVybnMgYW4gaW5kZXggb2YgYGNsYXNzVG9TZWFyY2hgIGluIGBjbGFzc05hbWVgIHRha2luZyB0b2tlbiBib3VuZGFyaWVzIGludG8gYWNjb3VudC5cbiAqXG4gKiBgY2xhc3NJbmRleE9mKCdBQiBBJywgJ0EnLCAwKWAgd2lsbCBiZSAzIChub3QgMCBzaW5jZSBgQUIhPT1BYClcbiAqXG4gKiBAcGFyYW0gY2xhc3NOYW1lIEEgc3RyaW5nIGNvbnRhaW5pbmcgY2xhc3NlcyAod2hpdGVzcGFjZSBzZXBhcmF0ZWQpXG4gKiBAcGFyYW0gY2xhc3NUb1NlYXJjaCBBIGNsYXNzIG5hbWUgdG8gbG9jYXRlXG4gKiBAcGFyYW0gc3RhcnRpbmdJbmRleCBTdGFydGluZyBsb2NhdGlvbiBvZiBzZWFyY2hcbiAqIEByZXR1cm5zIGFuIGluZGV4IG9mIHRoZSBsb2NhdGVkIGNsYXNzIChvciAtMSBpZiBub3QgZm91bmQpXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjbGFzc0luZGV4T2YoXG4gICAgY2xhc3NOYW1lOiBzdHJpbmcsIGNsYXNzVG9TZWFyY2g6IHN0cmluZywgc3RhcnRpbmdJbmRleDogbnVtYmVyKTogbnVtYmVyIHtcbiAgbmdEZXZNb2RlICYmIGFzc2VydE5vdEVxdWFsKGNsYXNzVG9TZWFyY2gsICcnLCAnY2FuIG5vdCBsb29rIGZvciBcIlwiIHN0cmluZy4nKTtcbiAgbGV0IGVuZCA9IGNsYXNzTmFtZS5sZW5ndGg7XG4gIHdoaWxlICh0cnVlKSB7XG4gICAgY29uc3QgZm91bmRJbmRleCA9IGNsYXNzTmFtZS5pbmRleE9mKGNsYXNzVG9TZWFyY2gsIHN0YXJ0aW5nSW5kZXgpO1xuICAgIGlmIChmb3VuZEluZGV4ID09PSAtMSkgcmV0dXJuIGZvdW5kSW5kZXg7XG4gICAgaWYgKGZvdW5kSW5kZXggPT09IDAgfHwgY2xhc3NOYW1lLmNoYXJDb2RlQXQoZm91bmRJbmRleCAtIDEpIDw9IENoYXJDb2RlLlNQQUNFKSB7XG4gICAgICAvLyBFbnN1cmUgdGhhdCBpdCBoYXMgbGVhZGluZyB3aGl0ZXNwYWNlXG4gICAgICBjb25zdCBsZW5ndGggPSBjbGFzc1RvU2VhcmNoLmxlbmd0aDtcbiAgICAgIGlmIChmb3VuZEluZGV4ICsgbGVuZ3RoID09PSBlbmQgfHxcbiAgICAgICAgICBjbGFzc05hbWUuY2hhckNvZGVBdChmb3VuZEluZGV4ICsgbGVuZ3RoKSA8PSBDaGFyQ29kZS5TUEFDRSkge1xuICAgICAgICAvLyBFbnN1cmUgdGhhdCBpdCBoYXMgdHJhaWxpbmcgd2hpdGVzcGFjZVxuICAgICAgICByZXR1cm4gZm91bmRJbmRleDtcbiAgICAgIH1cbiAgICB9XG4gICAgLy8gRmFsc2UgcG9zaXRpdmUsIGtlZXAgc2VhcmNoaW5nIGZyb20gd2hlcmUgd2UgbGVmdCBvZmYuXG4gICAgc3RhcnRpbmdJbmRleCA9IGZvdW5kSW5kZXggKyAxO1xuICB9XG59Il19
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright Google Inc. All Rights Reserved.
|
|
4
|
+
*
|
|
5
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
+
* found in the LICENSE file at https://angular.io/license
|
|
7
|
+
*/
|
|
8
|
+
import { concatStringsWithSpace } from '../../util/stringify';
|
|
9
|
+
import { assertFirstCreatePass } from '../assert';
|
|
10
|
+
import { getTView } from '../state';
|
|
11
|
+
/**
|
|
12
|
+
* Compute the static styling (class/style) from `TAttributes`.
|
|
13
|
+
*
|
|
14
|
+
* This function should be called during `firstCreatePass` only.
|
|
15
|
+
*
|
|
16
|
+
* @param tNode The `TNode` into which the styling information should be loaded.
|
|
17
|
+
* @param attrs `TAttributes` containing the styling information.
|
|
18
|
+
*/
|
|
19
|
+
export function computeStaticStyling(tNode, attrs) {
|
|
20
|
+
ngDevMode &&
|
|
21
|
+
assertFirstCreatePass(getTView(), 'Expecting to be called in first template pass only');
|
|
22
|
+
var styles = tNode.styles;
|
|
23
|
+
var classes = tNode.classes;
|
|
24
|
+
var mode = 0;
|
|
25
|
+
for (var i = 0; i < attrs.length; i++) {
|
|
26
|
+
var value = attrs[i];
|
|
27
|
+
if (typeof value === 'number') {
|
|
28
|
+
mode = value;
|
|
29
|
+
}
|
|
30
|
+
else if (mode == 1 /* Classes */) {
|
|
31
|
+
classes = concatStringsWithSpace(classes, value);
|
|
32
|
+
}
|
|
33
|
+
else if (mode == 2 /* Styles */) {
|
|
34
|
+
var style = value;
|
|
35
|
+
var styleValue = attrs[++i];
|
|
36
|
+
styles = concatStringsWithSpace(styles, style + ': ' + styleValue + ';');
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
styles !== null && (tNode.styles = styles);
|
|
40
|
+
classes !== null && (tNode.classes = classes);
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdGljX3N0eWxpbmcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb3JlL3NyYy9yZW5kZXIzL3N0eWxpbmcvc3RhdGljX3N0eWxpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztFQU1FO0FBRUYsT0FBTyxFQUFDLHNCQUFzQixFQUFDLE1BQU0sc0JBQXNCLENBQUM7QUFDNUQsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sV0FBVyxDQUFDO0FBRWhELE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxVQUFVLENBQUM7QUFFbEM7Ozs7Ozs7R0FPRztBQUNILE1BQU0sVUFBVSxvQkFBb0IsQ0FBQyxLQUFZLEVBQUUsS0FBa0I7SUFDbkUsU0FBUztRQUNMLHFCQUFxQixDQUFDLFFBQVEsRUFBRSxFQUFFLG9EQUFvRCxDQUFDLENBQUM7SUFDNUYsSUFBSSxNQUFNLEdBQWdCLEtBQUssQ0FBQyxNQUFNLENBQUM7SUFDdkMsSUFBSSxPQUFPLEdBQWdCLEtBQUssQ0FBQyxPQUFPLENBQUM7SUFDekMsSUFBSSxJQUFJLEdBQXNCLENBQUMsQ0FBQztJQUNoQyxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDLEVBQUUsRUFBRTtRQUNyQyxJQUFNLEtBQUssR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDdkIsSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLEVBQUU7WUFDN0IsSUFBSSxHQUFHLEtBQUssQ0FBQztTQUNkO2FBQU0sSUFBSSxJQUFJLG1CQUEyQixFQUFFO1lBQzFDLE9BQU8sR0FBRyxzQkFBc0IsQ0FBQyxPQUFPLEVBQUUsS0FBZSxDQUFDLENBQUM7U0FDNUQ7YUFBTSxJQUFJLElBQUksa0JBQTBCLEVBQUU7WUFDekMsSUFBTSxLQUFLLEdBQUcsS0FBZSxDQUFDO1lBQzlCLElBQU0sVUFBVSxHQUFHLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBVyxDQUFDO1lBQ3hDLE1BQU0sR0FBRyxzQkFBc0IsQ0FBQyxNQUFNLEVBQUUsS0FBSyxHQUFHLElBQUksR0FBRyxVQUFVLEdBQUcsR0FBRyxDQUFDLENBQUM7U0FDMUU7S0FDRjtJQUNELE1BQU0sS0FBSyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQyxDQUFDO0lBQzNDLE9BQU8sS0FBSyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQyxDQUFDO0FBQ2hELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiogQGxpY2Vuc2VcbiogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4qXG4qIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4qIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiovXG5cbmltcG9ydCB7Y29uY2F0U3RyaW5nc1dpdGhTcGFjZX0gZnJvbSAnLi4vLi4vdXRpbC9zdHJpbmdpZnknO1xuaW1wb3J0IHthc3NlcnRGaXJzdENyZWF0ZVBhc3N9IGZyb20gJy4uL2Fzc2VydCc7XG5pbXBvcnQge0F0dHJpYnV0ZU1hcmtlciwgVEF0dHJpYnV0ZXMsIFROb2RlfSBmcm9tICcuLi9pbnRlcmZhY2VzL25vZGUnO1xuaW1wb3J0IHtnZXRUVmlld30gZnJvbSAnLi4vc3RhdGUnO1xuXG4vKipcbiAqIENvbXB1dGUgdGhlIHN0YXRpYyBzdHlsaW5nIChjbGFzcy9zdHlsZSkgZnJvbSBgVEF0dHJpYnV0ZXNgLlxuICpcbiAqIFRoaXMgZnVuY3Rpb24gc2hvdWxkIGJlIGNhbGxlZCBkdXJpbmcgYGZpcnN0Q3JlYXRlUGFzc2Agb25seS5cbiAqXG4gKiBAcGFyYW0gdE5vZGUgVGhlIGBUTm9kZWAgaW50byB3aGljaCB0aGUgc3R5bGluZyBpbmZvcm1hdGlvbiBzaG91bGQgYmUgbG9hZGVkLlxuICogQHBhcmFtIGF0dHJzIGBUQXR0cmlidXRlc2AgY29udGFpbmluZyB0aGUgc3R5bGluZyBpbmZvcm1hdGlvbi5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNvbXB1dGVTdGF0aWNTdHlsaW5nKHROb2RlOiBUTm9kZSwgYXR0cnM6IFRBdHRyaWJ1dGVzKTogdm9pZCB7XG4gIG5nRGV2TW9kZSAmJlxuICAgICAgYXNzZXJ0Rmlyc3RDcmVhdGVQYXNzKGdldFRWaWV3KCksICdFeHBlY3RpbmcgdG8gYmUgY2FsbGVkIGluIGZpcnN0IHRlbXBsYXRlIHBhc3Mgb25seScpO1xuICBsZXQgc3R5bGVzOiBzdHJpbmd8bnVsbCA9IHROb2RlLnN0eWxlcztcbiAgbGV0IGNsYXNzZXM6IHN0cmluZ3xudWxsID0gdE5vZGUuY2xhc3NlcztcbiAgbGV0IG1vZGU6IEF0dHJpYnV0ZU1hcmtlcnwwID0gMDtcbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBhdHRycy5sZW5ndGg7IGkrKykge1xuICAgIGNvbnN0IHZhbHVlID0gYXR0cnNbaV07XG4gICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ251bWJlcicpIHtcbiAgICAgIG1vZGUgPSB2YWx1ZTtcbiAgICB9IGVsc2UgaWYgKG1vZGUgPT0gQXR0cmlidXRlTWFya2VyLkNsYXNzZXMpIHtcbiAgICAgIGNsYXNzZXMgPSBjb25jYXRTdHJpbmdzV2l0aFNwYWNlKGNsYXNzZXMsIHZhbHVlIGFzIHN0cmluZyk7XG4gICAgfSBlbHNlIGlmIChtb2RlID09IEF0dHJpYnV0ZU1hcmtlci5TdHlsZXMpIHtcbiAgICAgIGNvbnN0IHN0eWxlID0gdmFsdWUgYXMgc3RyaW5nO1xuICAgICAgY29uc3Qgc3R5bGVWYWx1ZSA9IGF0dHJzWysraV0gYXMgc3RyaW5nO1xuICAgICAgc3R5bGVzID0gY29uY2F0U3RyaW5nc1dpdGhTcGFjZShzdHlsZXMsIHN0eWxlICsgJzogJyArIHN0eWxlVmFsdWUgKyAnOycpO1xuICAgIH1cbiAgfVxuICBzdHlsZXMgIT09IG51bGwgJiYgKHROb2RlLnN0eWxlcyA9IHN0eWxlcyk7XG4gIGNsYXNzZXMgIT09IG51bGwgJiYgKHROb2RlLmNsYXNzZXMgPSBjbGFzc2VzKTtcbn0iXX0=
|