@angular/core 8.0.0 → 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.
Files changed (191) hide show
  1. package/bundles/core-testing.umd.js +35 -9
  2. package/bundles/core-testing.umd.js.map +1 -1
  3. package/bundles/core-testing.umd.min.js +10 -10
  4. package/bundles/core-testing.umd.min.js.map +1 -1
  5. package/bundles/core.umd.js +11356 -9352
  6. package/bundles/core.umd.js.map +1 -1
  7. package/bundles/core.umd.min.js +201 -139
  8. package/bundles/core.umd.min.js.map +1 -1
  9. package/core.d.ts +1302 -404
  10. package/core.metadata.json +1 -1
  11. package/esm2015/core.js +2 -3
  12. package/esm2015/index.js +2 -2
  13. package/esm2015/public_api.js +2 -2
  14. package/esm2015/src/application_ref.js +7 -1
  15. package/esm2015/src/codegen_private_exports.js +2 -2
  16. package/esm2015/src/compiler/compiler_facade_interface.js +1 -1
  17. package/esm2015/src/core.js +4 -4
  18. package/esm2015/src/core_private_export.js +3 -1
  19. package/esm2015/src/core_render3_private_export.js +5 -3
  20. package/esm2015/src/debug/debug_node.js +4 -4
  21. package/esm2015/src/di/index.js +3 -3
  22. package/esm2015/src/di/injector.js +24 -96
  23. package/esm2015/src/di/injector_compatibility.js +103 -6
  24. package/esm2015/src/di/interface/defs.js +24 -3
  25. package/esm2015/src/di/r3_injector.js +82 -49
  26. package/esm2015/src/di/reflective_injector.js +3 -2
  27. package/esm2015/src/di.js +1 -1
  28. package/esm2015/src/i18n/locale_data.js +61 -0
  29. package/esm2015/src/i18n/locale_data_api.js +53 -0
  30. package/esm2015/src/i18n/locale_en.js +51 -0
  31. package/esm2015/src/i18n/localization.js +37 -0
  32. package/esm2015/src/linker/ng_module_factory_loader.js +4 -52
  33. package/esm2015/src/linker/ng_module_factory_registration.js +83 -0
  34. package/esm2015/src/metadata/ng_module.js +6 -1
  35. package/esm2015/src/metadata/resource_loading.js +2 -2
  36. package/esm2015/src/reflection/reflection_capabilities.js +14 -3
  37. package/esm2015/src/render3/assert.js +3 -2
  38. package/esm2015/src/render3/component.js +11 -5
  39. package/esm2015/src/render3/debug.js +23 -15
  40. package/esm2015/src/render3/definition.js +12 -2
  41. package/esm2015/src/render3/errors.js +29 -1
  42. package/esm2015/src/render3/features/inherit_definition_feature.js +51 -37
  43. package/esm2015/src/render3/fields.js +3 -1
  44. package/esm2015/src/render3/i18n.js +76 -465
  45. package/esm2015/src/render3/index.js +3 -3
  46. package/esm2015/src/render3/instructions/all.js +9 -4
  47. package/esm2015/src/render3/instructions/attribute.js +28 -0
  48. package/esm2015/src/render3/instructions/attribute_interpolation.js +376 -0
  49. package/esm2015/src/render3/instructions/container.js +17 -16
  50. package/esm2015/src/render3/instructions/element.js +57 -35
  51. package/esm2015/src/render3/instructions/element_container.js +9 -8
  52. package/esm2015/src/render3/instructions/embedded_view.js +9 -12
  53. package/esm2015/src/render3/instructions/interpolation.js +375 -0
  54. package/esm2015/src/render3/instructions/listener.js +3 -2
  55. package/esm2015/src/render3/instructions/projection.js +6 -6
  56. package/esm2015/src/render3/instructions/property.js +10 -4
  57. package/esm2015/src/render3/instructions/property_interpolation.js +49 -382
  58. package/esm2015/src/render3/instructions/shared.js +82 -118
  59. package/esm2015/src/render3/instructions/styling.js +189 -236
  60. package/esm2015/src/render3/instructions/text.js +8 -7
  61. package/esm2015/src/render3/instructions/text_interpolation.js +357 -0
  62. package/esm2015/src/render3/interfaces/container.js +9 -5
  63. package/esm2015/src/render3/interfaces/definition.js +12 -6
  64. package/esm2015/src/render3/interfaces/node.js +20 -8
  65. package/esm2015/src/render3/interfaces/styling.js +16 -15
  66. package/esm2015/src/render3/interfaces/view.js +2 -2
  67. package/esm2015/src/render3/jit/directive.js +14 -5
  68. package/esm2015/src/render3/jit/environment.js +30 -15
  69. package/esm2015/src/render3/jit/module.js +38 -19
  70. package/esm2015/src/render3/ng_module_ref.js +39 -3
  71. package/esm2015/src/render3/node_manipulation.js +45 -43
  72. package/esm2015/src/render3/node_selector_matcher.js +14 -13
  73. package/esm2015/src/render3/query.js +77 -61
  74. package/esm2015/src/render3/state.js +33 -6
  75. package/esm2015/src/render3/styling/class_and_style_bindings.js +91 -79
  76. package/esm2015/src/render3/styling/host_instructions_queue.js +8 -5
  77. package/esm2015/src/render3/styling/shared.js +2 -2
  78. package/esm2015/src/render3/styling/util.js +2 -2
  79. package/esm2015/src/render3/styling_next/bindings.js +602 -0
  80. package/esm2015/src/render3/styling_next/instructions.js +366 -0
  81. package/esm2015/src/render3/styling_next/interfaces.js +374 -0
  82. package/esm2015/src/render3/styling_next/map_based_bindings.js +408 -0
  83. package/esm2015/src/render3/styling_next/state.js +51 -0
  84. package/esm2015/src/render3/styling_next/styling_debug.js +291 -0
  85. package/esm2015/src/render3/styling_next/util.js +259 -0
  86. package/esm2015/src/render3/util/attrs_utils.js +4 -3
  87. package/esm2015/src/render3/util/debug_utils.js +18 -0
  88. package/esm2015/src/render3/util/view_traversal_utils.js +2 -2
  89. package/esm2015/src/render3/view_engine_compatibility.js +24 -10
  90. package/esm2015/src/sanitization/sanitization.js +17 -7
  91. package/esm2015/src/sanitization/style_sanitizer.js +11 -1
  92. package/esm2015/src/util/ng_dev_mode.js +7 -3
  93. package/esm2015/src/version.js +1 -1
  94. package/esm2015/src/view/ng_module.js +3 -3
  95. package/esm2015/src/view/util.js +2 -2
  96. package/esm2015/testing/src/r3_test_bed_compiler.js +44 -12
  97. package/esm5/core.js +2 -3
  98. package/esm5/src/application_ref.js +6 -1
  99. package/esm5/src/codegen_private_exports.js +2 -2
  100. package/esm5/src/compiler/compiler_facade_interface.js +1 -1
  101. package/esm5/src/core_private_export.js +3 -1
  102. package/esm5/src/core_render3_private_export.js +5 -3
  103. package/esm5/src/debug/debug_node.js +4 -4
  104. package/esm5/src/di/index.js +3 -3
  105. package/esm5/src/di/injector.js +14 -74
  106. package/esm5/src/di/injector_compatibility.js +77 -6
  107. package/esm5/src/di/interface/defs.js +24 -3
  108. package/esm5/src/di/r3_injector.js +60 -37
  109. package/esm5/src/di/reflective_injector.js +3 -2
  110. package/esm5/src/i18n/locale_data.js +38 -0
  111. package/esm5/src/i18n/locale_data_api.js +46 -0
  112. package/esm5/src/i18n/locale_en.js +39 -0
  113. package/esm5/src/i18n/localization.js +29 -0
  114. package/esm5/src/linker/ng_module_factory_loader.js +4 -32
  115. package/esm5/src/linker/ng_module_factory_registration.js +50 -0
  116. package/esm5/src/metadata/ng_module.js +1 -1
  117. package/esm5/src/metadata/resource_loading.js +2 -2
  118. package/esm5/src/reflection/reflection_capabilities.js +14 -3
  119. package/esm5/src/render3/assert.js +2 -1
  120. package/esm5/src/render3/component.js +10 -4
  121. package/esm5/src/render3/debug.js +17 -10
  122. package/esm5/src/render3/definition.js +8 -2
  123. package/esm5/src/render3/errors.js +14 -1
  124. package/esm5/src/render3/features/inherit_definition_feature.js +41 -36
  125. package/esm5/src/render3/fields.js +2 -1
  126. package/esm5/src/render3/i18n.js +67 -437
  127. package/esm5/src/render3/index.js +3 -3
  128. package/esm5/src/render3/instructions/all.js +6 -1
  129. package/esm5/src/render3/instructions/attribute.js +22 -0
  130. package/esm5/src/render3/instructions/attribute_interpolation.js +346 -0
  131. package/esm5/src/render3/instructions/container.js +16 -15
  132. package/esm5/src/render3/instructions/element.js +43 -32
  133. package/esm5/src/render3/instructions/element_container.js +9 -8
  134. package/esm5/src/render3/instructions/embedded_view.js +8 -11
  135. package/esm5/src/render3/instructions/interpolation.js +243 -0
  136. package/esm5/src/render3/instructions/listener.js +3 -2
  137. package/esm5/src/render3/instructions/projection.js +6 -6
  138. package/esm5/src/render3/instructions/property.js +10 -4
  139. package/esm5/src/render3/instructions/property_interpolation.js +40 -254
  140. package/esm5/src/render3/instructions/shared.js +70 -105
  141. package/esm5/src/render3/instructions/styling.js +167 -209
  142. package/esm5/src/render3/instructions/text.js +8 -7
  143. package/esm5/src/render3/instructions/text_interpolation.js +264 -0
  144. package/esm5/src/render3/interfaces/container.js +8 -2
  145. package/esm5/src/render3/interfaces/definition.js +1 -1
  146. package/esm5/src/render3/interfaces/node.js +1 -8
  147. package/esm5/src/render3/interfaces/styling.js +2 -2
  148. package/esm5/src/render3/interfaces/view.js +1 -1
  149. package/esm5/src/render3/jit/directive.js +12 -5
  150. package/esm5/src/render3/jit/environment.js +30 -15
  151. package/esm5/src/render3/jit/module.js +23 -18
  152. package/esm5/src/render3/ng_module_ref.js +37 -3
  153. package/esm5/src/render3/node_manipulation.js +39 -38
  154. package/esm5/src/render3/node_selector_matcher.js +14 -13
  155. package/esm5/src/render3/query.js +75 -53
  156. package/esm5/src/render3/state.js +29 -5
  157. package/esm5/src/render3/styling/class_and_style_bindings.js +79 -65
  158. package/esm5/src/render3/styling/host_instructions_queue.js +6 -3
  159. package/esm5/src/render3/styling/shared.js +2 -2
  160. package/esm5/src/render3/styling/util.js +2 -2
  161. package/esm5/src/render3/styling_next/bindings.js +446 -0
  162. package/esm5/src/render3/styling_next/instructions.js +277 -0
  163. package/esm5/src/render3/styling_next/interfaces.js +1 -0
  164. package/esm5/src/render3/styling_next/map_based_bindings.js +324 -0
  165. package/esm5/src/render3/styling_next/state.js +23 -0
  166. package/esm5/src/render3/styling_next/styling_debug.js +130 -0
  167. package/esm5/src/render3/styling_next/util.js +147 -0
  168. package/esm5/src/render3/util/attrs_utils.js +4 -3
  169. package/esm5/src/render3/util/debug_utils.js +11 -0
  170. package/esm5/src/render3/util/view_traversal_utils.js +2 -2
  171. package/esm5/src/render3/view_engine_compatibility.js +23 -10
  172. package/esm5/src/sanitization/sanitization.js +14 -6
  173. package/esm5/src/sanitization/style_sanitizer.js +1 -1
  174. package/esm5/src/util/ng_dev_mode.js +7 -3
  175. package/esm5/src/version.js +1 -1
  176. package/esm5/src/view/ng_module.js +3 -3
  177. package/esm5/src/view/util.js +2 -2
  178. package/esm5/testing/src/r3_test_bed_compiler.js +37 -11
  179. package/fesm2015/core.js +13481 -10733
  180. package/fesm2015/core.js.map +1 -1
  181. package/fesm2015/testing.js +43 -11
  182. package/fesm2015/testing.js.map +1 -1
  183. package/fesm5/core.js +11255 -9269
  184. package/fesm5/core.js.map +1 -1
  185. package/fesm5/testing.js +36 -10
  186. package/fesm5/testing.js.map +1 -1
  187. package/package.json +1 -1
  188. package/schematics/migrations/template-var-assignment/index.js +2 -2
  189. package/src/r3_symbols.d.ts +5 -1
  190. package/testing/testing.d.ts +1 -1
  191. 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"]}