@sapui5/sap.fe.core 1.94.0 → 1.96.3

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 (182) hide show
  1. package/package.json +1 -1
  2. package/src/sap/fe/core/.library +1 -1
  3. package/src/sap/fe/core/AnnotationHelper.js +3 -3
  4. package/src/sap/fe/core/AppComponent.js +10 -41
  5. package/src/sap/fe/core/AppStateHandler.js +18 -4
  6. package/src/sap/fe/core/BaseController.js +1 -1
  7. package/src/sap/fe/core/BusyLocker.js +13 -1
  8. package/src/sap/fe/core/CommonUtils.js +372 -9
  9. package/src/sap/fe/core/ExtensionAPI.js +1 -1
  10. package/src/sap/fe/core/PageController.js +11 -3
  11. package/src/sap/fe/core/RouterProxy.js +59 -69
  12. package/src/sap/fe/core/Synchronization.js +1 -1
  13. package/src/sap/fe/core/TemplateComponent.js +9 -3
  14. package/src/sap/fe/core/TemplateModel.js +1 -1
  15. package/src/sap/fe/core/TransactionHelper.js +157 -111
  16. package/src/sap/fe/core/actions/draft.js +1 -1
  17. package/src/sap/fe/core/actions/messageHandling.js +1 -1
  18. package/src/sap/fe/core/actions/nonDraft.js +1 -1
  19. package/src/sap/fe/core/actions/operations.js +25 -3
  20. package/src/sap/fe/core/actions/sticky.js +1 -1
  21. package/src/sap/fe/core/controllerextensions/ControllerExtensionMetadata.js +1 -1
  22. package/src/sap/fe/core/controllerextensions/EditFlow.js +89 -54
  23. package/src/sap/fe/core/controllerextensions/IntentBasedNavigation.js +1 -1
  24. package/src/sap/fe/core/controllerextensions/InternalEditFlow.js +14 -7
  25. package/src/sap/fe/core/controllerextensions/InternalIntentBasedNavigation.js +128 -25
  26. package/src/sap/fe/core/controllerextensions/InternalRouting.js +197 -210
  27. package/src/sap/fe/core/controllerextensions/KPIManagement.js +844 -168
  28. package/src/sap/fe/core/controllerextensions/KPIManagement.ts +903 -189
  29. package/src/sap/fe/core/controllerextensions/MessageHandler.js +1 -1
  30. package/src/sap/fe/core/controllerextensions/PageReady.js +31 -17
  31. package/src/sap/fe/core/controllerextensions/PageReady.ts +50 -15
  32. package/src/sap/fe/core/controllerextensions/Paginator.js +20 -4
  33. package/src/sap/fe/core/controllerextensions/Placeholder.js +134 -271
  34. package/src/sap/fe/core/controllerextensions/Routing.js +1 -1
  35. package/src/sap/fe/core/controllerextensions/RoutingListener.js +1 -1
  36. package/src/sap/fe/core/controllerextensions/Share.js +20 -7
  37. package/src/sap/fe/core/controllerextensions/SideEffects.js +2 -3
  38. package/src/sap/fe/core/controllerextensions/SideEffects.ts +13 -12
  39. package/src/sap/fe/core/controllerextensions/ViewState.js +174 -7
  40. package/src/sap/fe/core/controls/ActionParameterDialog.fragment.xml +39 -34
  41. package/src/sap/fe/core/controls/ActionParameterDialogValueHelp.fragment.xml +35 -0
  42. package/src/sap/fe/core/controls/CommandExecution.js +1 -1
  43. package/src/sap/fe/core/controls/ConditionalWrapper.js +1 -1
  44. package/src/sap/fe/core/controls/CustomQuickViewPage.js +4 -1
  45. package/src/sap/fe/core/controls/DataLossOrDraftDiscard/DataLossOrDraftDiscardHandler.js +1 -1
  46. package/src/sap/fe/core/controls/FieldWrapper.js +1 -1
  47. package/src/sap/fe/core/controls/FilterBar.js +1 -1
  48. package/src/sap/fe/core/controls/FormElementWrapper.js +1 -1
  49. package/src/sap/fe/core/controls/MultiValueParameterDelegate.js +45 -0
  50. package/src/sap/fe/core/controls/filterbar/FilterContainer.js +5 -8
  51. package/src/sap/fe/core/controls/filterbar/VisualFilter.js +83 -23
  52. package/src/sap/fe/core/controls/filterbar/VisualFilterContainer.js +2 -6
  53. package/src/sap/fe/core/controls/filterbar/utils/VisualFilterUtils.js +25 -18
  54. package/src/sap/fe/core/converters/ConverterContext.js +18 -4
  55. package/src/sap/fe/core/converters/ConverterContext.ts +13 -3
  56. package/src/sap/fe/core/converters/ManifestSettings.js +1 -1
  57. package/src/sap/fe/core/converters/ManifestSettings.ts +4 -1
  58. package/src/sap/fe/core/converters/MetaModelConverter.js +855 -868
  59. package/src/sap/fe/core/converters/MetaModelConverter.ts +763 -826
  60. package/src/sap/fe/core/converters/annotations/DataField.js +52 -2
  61. package/src/sap/fe/core/converters/annotations/DataField.ts +52 -2
  62. package/src/sap/fe/core/converters/controls/Common/Action.js +6 -1
  63. package/src/sap/fe/core/converters/controls/Common/Action.ts +3 -0
  64. package/src/sap/fe/core/converters/controls/Common/Chart.js +85 -6
  65. package/src/sap/fe/core/converters/controls/Common/Chart.ts +80 -2
  66. package/src/sap/fe/core/converters/controls/Common/DataVisualization.js +15 -16
  67. package/src/sap/fe/core/converters/controls/Common/DataVisualization.ts +16 -30
  68. package/src/sap/fe/core/converters/controls/Common/Form.js +17 -8
  69. package/src/sap/fe/core/converters/controls/Common/Form.ts +11 -3
  70. package/src/sap/fe/core/converters/controls/Common/KPI.js +287 -109
  71. package/src/sap/fe/core/converters/controls/Common/KPI.ts +314 -139
  72. package/src/sap/fe/core/converters/controls/Common/Table.js +273 -105
  73. package/src/sap/fe/core/converters/controls/Common/Table.ts +319 -111
  74. package/src/sap/fe/core/converters/controls/ListReport/FilterBar.js +8 -20
  75. package/src/sap/fe/core/converters/controls/ListReport/FilterBar.ts +11 -15
  76. package/src/sap/fe/core/converters/controls/ListReport/VisualFilters.js +44 -15
  77. package/src/sap/fe/core/converters/controls/ListReport/VisualFilters.ts +41 -19
  78. package/src/sap/fe/core/converters/controls/ObjectPage/Avatar.js +74 -0
  79. package/src/sap/fe/core/converters/controls/ObjectPage/Avatar.ts +50 -0
  80. package/src/sap/fe/core/converters/controls/ObjectPage/SubSection.js +15 -7
  81. package/src/sap/fe/core/converters/controls/ObjectPage/SubSection.ts +27 -6
  82. package/src/sap/fe/core/converters/helpers/Aggregation.js +18 -30
  83. package/src/sap/fe/core/converters/helpers/Aggregation.ts +17 -28
  84. package/src/sap/fe/core/converters/helpers/BindingHelper.js +3 -2
  85. package/src/sap/fe/core/converters/helpers/BindingHelper.ts +2 -2
  86. package/src/sap/fe/core/converters/helpers/ID.js +1 -1
  87. package/src/sap/fe/core/converters/helpers/ID.ts +2 -2
  88. package/src/sap/fe/core/converters/helpers/IssueManager.js +3 -3
  89. package/src/sap/fe/core/converters/helpers/IssueManager.ts +2 -2
  90. package/src/sap/fe/core/converters/helpers/SelectionVariantHelper.js +11 -6
  91. package/src/sap/fe/core/converters/helpers/SelectionVariantHelper.ts +9 -5
  92. package/src/sap/fe/core/converters/objectPage/FormMenuActions.js +15 -2
  93. package/src/sap/fe/core/converters/objectPage/FormMenuActions.ts +14 -14
  94. package/src/sap/fe/core/converters/objectPage/HeaderAndFooterAction.js +2 -2
  95. package/src/sap/fe/core/converters/objectPage/HeaderAndFooterAction.ts +1 -1
  96. package/src/sap/fe/core/converters/templates/ListReportConverter.js +73 -8
  97. package/src/sap/fe/core/converters/templates/ListReportConverter.ts +70 -10
  98. package/src/sap/fe/core/converters/templates/ObjectPageConverter.js +82 -16
  99. package/src/sap/fe/core/converters/templates/ObjectPageConverter.ts +100 -17
  100. package/src/sap/fe/core/designtime/AppComponent.designtime.js +1 -1
  101. package/src/sap/fe/core/formatters/FPMFormatter.js +1 -1
  102. package/src/sap/fe/core/formatters/FPMFormatter.ts +8 -3
  103. package/src/sap/fe/core/fpm/Component.js +2 -2
  104. package/src/sap/fe/core/helpers/BindingExpression.js +17 -2
  105. package/src/sap/fe/core/helpers/BindingExpression.ts +14 -1
  106. package/src/sap/fe/core/helpers/DynamicAnnotationPathHelper.js +1 -1
  107. package/src/sap/fe/core/helpers/EditState.js +1 -1
  108. package/src/sap/fe/core/helpers/ExcelFormatHelper.js +1 -3
  109. package/src/sap/fe/core/helpers/FPMHelper.js +1 -1
  110. package/src/sap/fe/core/helpers/ModelHelper.js +28 -1
  111. package/src/sap/fe/core/helpers/PasteHelper.js +7 -1
  112. package/src/sap/fe/core/helpers/SemanticDateOperators.js +1 -1
  113. package/src/sap/fe/core/helpers/SemanticKeyHelper.js +3 -3
  114. package/src/sap/fe/core/helpers/StableIdHelper.js +2 -2
  115. package/src/sap/fe/core/helpers/StableIdHelper.ts +1 -1
  116. package/src/sap/fe/core/library.js +2 -2
  117. package/src/sap/fe/core/library.support.js +1 -1
  118. package/src/sap/fe/core/messagebundle.properties +30 -1
  119. package/src/sap/fe/core/messagebundle_ar.properties +14 -0
  120. package/src/sap/fe/core/messagebundle_bg.properties +14 -0
  121. package/src/sap/fe/core/messagebundle_ca.properties +15 -1
  122. package/src/sap/fe/core/messagebundle_cs.properties +14 -0
  123. package/src/sap/fe/core/messagebundle_cy.properties +14 -0
  124. package/src/sap/fe/core/messagebundle_da.properties +14 -0
  125. package/src/sap/fe/core/messagebundle_de.properties +14 -0
  126. package/src/sap/fe/core/messagebundle_el.properties +14 -0
  127. package/src/sap/fe/core/messagebundle_en.properties +14 -0
  128. package/src/sap/fe/core/messagebundle_en_GB.properties +14 -0
  129. package/src/sap/fe/core/messagebundle_en_US_sappsd.properties +14 -0
  130. package/src/sap/fe/core/messagebundle_en_US_saprigi.properties +20 -2
  131. package/src/sap/fe/core/messagebundle_en_US_saptrc.properties +14 -0
  132. package/src/sap/fe/core/messagebundle_es.properties +21 -7
  133. package/src/sap/fe/core/messagebundle_es_MX.properties +15 -1
  134. package/src/sap/fe/core/messagebundle_et.properties +14 -0
  135. package/src/sap/fe/core/messagebundle_fi.properties +14 -0
  136. package/src/sap/fe/core/messagebundle_fr.properties +18 -4
  137. package/src/sap/fe/core/messagebundle_fr_CA.properties +14 -0
  138. package/src/sap/fe/core/messagebundle_hi.properties +14 -0
  139. package/src/sap/fe/core/messagebundle_hr.properties +14 -0
  140. package/src/sap/fe/core/messagebundle_hu.properties +14 -0
  141. package/src/sap/fe/core/messagebundle_id.properties +14 -0
  142. package/src/sap/fe/core/messagebundle_it.properties +14 -0
  143. package/src/sap/fe/core/messagebundle_iw.properties +15 -1
  144. package/src/sap/fe/core/messagebundle_ja.properties +14 -0
  145. package/src/sap/fe/core/messagebundle_kk.properties +14 -0
  146. package/src/sap/fe/core/messagebundle_ko.properties +14 -0
  147. package/src/sap/fe/core/messagebundle_lt.properties +14 -0
  148. package/src/sap/fe/core/messagebundle_lv.properties +14 -0
  149. package/src/sap/fe/core/messagebundle_ms.properties +14 -0
  150. package/src/sap/fe/core/messagebundle_nl.properties +18 -4
  151. package/src/sap/fe/core/messagebundle_no.properties +15 -1
  152. package/src/sap/fe/core/messagebundle_pl.properties +15 -1
  153. package/src/sap/fe/core/messagebundle_pt.properties +14 -0
  154. package/src/sap/fe/core/messagebundle_pt_PT.properties +14 -0
  155. package/src/sap/fe/core/messagebundle_ro.properties +14 -0
  156. package/src/sap/fe/core/messagebundle_ru.properties +14 -0
  157. package/src/sap/fe/core/messagebundle_sh.properties +14 -0
  158. package/src/sap/fe/core/messagebundle_sk.properties +14 -0
  159. package/src/sap/fe/core/messagebundle_sl.properties +14 -0
  160. package/src/sap/fe/core/messagebundle_sv.properties +14 -0
  161. package/src/sap/fe/core/messagebundle_th.properties +14 -0
  162. package/src/sap/fe/core/messagebundle_tr.properties +14 -0
  163. package/src/sap/fe/core/messagebundle_uk.properties +14 -0
  164. package/src/sap/fe/core/messagebundle_vi.properties +14 -0
  165. package/src/sap/fe/core/messagebundle_zh_CN.properties +14 -0
  166. package/src/sap/fe/core/messagebundle_zh_TW.properties +14 -0
  167. package/src/sap/fe/core/services/CacheHandlerServiceFactory.js +1 -1
  168. package/src/sap/fe/core/services/NavigationServiceFactory.js +1 -1
  169. package/src/sap/fe/core/services/ResourceModelServiceFactory.js +1 -1
  170. package/src/sap/fe/core/services/RoutingServiceFactory.js +114 -44
  171. package/src/sap/fe/core/services/SideEffectsServiceFactory.js +2 -2
  172. package/src/sap/fe/core/services/SideEffectsServiceFactory.ts +1 -1
  173. package/src/sap/fe/core/services/TemplatedViewServiceFactory.js +12 -2
  174. package/src/sap/fe/core/services/view/TemplatingErrorPage.controller.js +1 -1
  175. package/src/sap/fe/core/templating/DataModelPathHelper.js +3 -14
  176. package/src/sap/fe/core/templating/DataModelPathHelper.ts +3 -10
  177. package/src/sap/fe/core/templating/EntitySetHelper.js +13 -3
  178. package/src/sap/fe/core/templating/EntitySetHelper.ts +4 -0
  179. package/src/sap/fe/core/templating/FilterHelper.js +2 -2
  180. package/src/sap/fe/core/templating/FilterHelper.ts +1 -1
  181. package/src/sap/fe/core/templating/UIFormatters.js +41 -3
  182. package/src/sap/fe/core/templating/UIFormatters.ts +74 -2
@@ -1,6 +1,6 @@
1
1
  /*!
2
2
  * SAPUI5
3
- * (c) Copyright 2009-2021 SAP SE. All rights reserved.
3
+ * (c) Copyright 2009-2022 SAP SE. All rights reserved.
4
4
  */
5
5
  /* eslint-disable no-alert */
6
6
  sap.ui.define(
@@ -128,6 +128,7 @@ sap.ui.define(
128
128
  this._bDisableOnHashChange = false;
129
129
  this._bIgnoreRestore = false;
130
130
  this._bCleanedRestore = false;
131
+ this._bForceFocus = true; // Trigger the focus mechanism for the first view displayed by the app
131
132
  },
132
133
 
133
134
  destroy: function() {
@@ -158,6 +159,14 @@ sap.ui.define(
158
159
  return this._oRouter.getHashChanger().getHash();
159
160
  },
160
161
 
162
+ isFocusForced: function() {
163
+ return this._bForceFocus;
164
+ },
165
+
166
+ setFocusForced: function(bForced) {
167
+ this._bForceFocus = bForced;
168
+ },
169
+
161
170
  /**
162
171
  * Resets the internal variable sIAppStateKey.
163
172
  *
@@ -180,42 +189,34 @@ sap.ui.define(
180
189
  * @param {string} sHash Hash to be navigated to
181
190
  * @param {boolean} bPreserveHistory If set to true, non-ancestor entries in history will be retained
182
191
  * @param {boolean} bDisablePreservationCache If set to true, cache preservation mechanism is disabled for the current navigation
183
- * @returns {Promise} Promise that is resolved when the navigation is finalized
192
+ * @param {boolean} bForceFocus If set to true, the logic to set the focus once the navigation is finalized will be triggered (onPageReady)
193
+ * @param {boolean} bPreserveShellBackNavigationHandler If not set to false, the back navigation is set to undefined
194
+ * @returns {Promise} Promise (resolved when the navigation is finalized) that returns 'true' if a navigation took place, 'false' if the navigation didn't happen
184
195
  * @ui5-restricted
185
196
  */
186
- navToHash: function(sHash, bPreserveHistory, bDisablePreservationCache) {
197
+ navToHash: function(sHash, bPreserveHistory, bDisablePreservationCache, bForceFocus, bPreserveShellBackNavigationHandler) {
187
198
  var that = this;
188
-
199
+ if (bPreserveShellBackNavigationHandler !== false) {
200
+ this._oShellServices.setBackNavigation();
201
+ }
189
202
  if (this._oRouteMatchSynchronization) {
190
203
  return this._oRouteMatchSynchronization.waitFor().then(function() {
191
204
  that._oRouteMatchSynchronization = null;
192
- return that._internalNavToHash(sHash, bPreserveHistory, bDisablePreservationCache);
205
+ return that._internalNavToHash(sHash, bPreserveHistory, bDisablePreservationCache, bForceFocus);
193
206
  });
194
207
  } else {
195
208
  if (this._bActivateRouteMatchSynchro) {
196
209
  this.waitForRouteMatchBeforeNavigation();
197
210
  }
198
- return that._internalNavToHash(sHash, bPreserveHistory, bDisablePreservationCache);
211
+ return that._internalNavToHash(sHash, bPreserveHistory, bDisablePreservationCache, bForceFocus);
199
212
  }
200
213
  },
201
214
 
202
- _internalNavToHash: function(sHash, bPreserveHistory, bDisablePreservationCache) {
203
- var that = this,
204
- sLastFocusControlId = sap.ui.getCore().getCurrentFocusedControlId(),
205
- sLastFocusInfo =
206
- sLastFocusControlId && sap.ui.getCore().byId(sLastFocusControlId)
207
- ? sap.ui
208
- .getCore()
209
- .byId(sLastFocusControlId)
210
- .getFocusInfo()
211
- : null,
212
- shashBeforeRoutechanged = this.getHash();
213
-
215
+ _internalNavToHash: function(sHash, bPreserveHistory, bDisablePreservationCache, bForceFocus) {
214
216
  // Add the app state in the hash if needed
215
217
  if (this.fclEnabled && this.sIAppStateKey && !findAppStateInHash(sHash)) {
216
218
  sHash = setAppStateInHash(sHash, this.sIAppStateKey);
217
219
  }
218
- var oNewState = this._extractStateFromHash(sHash);
219
220
 
220
221
  if (!this.checkHashWithGuard(sHash)) {
221
222
  if (!this.oResourceBundle) {
@@ -230,11 +231,24 @@ sap.ui.define(
230
231
  }
231
232
  this.bIsGuardCrossAllowed = true;
232
233
  }
234
+
235
+ // In case the navigation will cause a new view to be displayed, we force the focus
236
+ // I.e. if the keys for the hash we're navigating to is a superset of the current hash keys.
237
+ var oNewState = this._extractStateFromHash(sHash);
238
+ if (!this._bForceFocus) {
239
+ // If the focus was already forced, keep it
240
+ var aCurrentHashKeys = this._extractKeysFromHash(this.getHash());
241
+ this._bForceFocus =
242
+ bForceFocus ||
243
+ (aCurrentHashKeys.length < oNewState.keys.length &&
244
+ aCurrentHashKeys.every(function(key, index) {
245
+ return key === oNewState.keys[index];
246
+ }));
247
+ }
248
+
233
249
  var oHistoryAction = this._pushNewState(oNewState, false, bPreserveHistory, bDisablePreservationCache);
234
250
 
235
- return this._rebuildBrowserHistory(oHistoryAction, false).then(function() {
236
- that.storeFocusForHash(sLastFocusControlId, sLastFocusInfo, shashBeforeRoutechanged);
237
- });
251
+ return this._rebuildBrowserHistory(oHistoryAction, false);
238
252
  },
239
253
 
240
254
  /**
@@ -258,34 +272,6 @@ sap.ui.define(
258
272
  }
259
273
  },
260
274
 
261
- getFocusControlForCurrentHash: function() {
262
- var sCurrenthash = this.getHash();
263
- var oLastFocusedControl;
264
- for (var i = this._oManagedHistory.length - 1; i >= 0; i--) {
265
- if (sCurrenthash === this._oManagedHistory[i].hash) {
266
- oLastFocusedControl = this._oManagedHistory[i].oLastFocusControl;
267
- break;
268
- } else {
269
- this._oManagedHistory[i].oLastFocusControl = undefined;
270
- }
271
- }
272
-
273
- return oLastFocusedControl;
274
- },
275
-
276
- storeFocusForHash: function(sLastFocusControlId, sLastFocusInfo, sHash) {
277
- var oManagedhistory = this._oManagedHistory;
278
- for (var i = 0; i < oManagedhistory.length; i++) {
279
- if (sHash === oManagedhistory[i].hash) {
280
- oManagedhistory[i].oLastFocusControl = {
281
- controlId: sLastFocusControlId,
282
- focusInfo: sLastFocusInfo
283
- };
284
- break;
285
- }
286
- }
287
- },
288
-
289
275
  /**
290
276
  * Navigates back in the history.
291
277
  *
@@ -316,7 +302,6 @@ sap.ui.define(
316
302
 
317
303
  /**
318
304
  * Navigates to a route with parameters.
319
- *
320
305
  * @param {string} sRouteName The route name to be navigated to
321
306
  * @param {object} oParameters Parameters for the navigation
322
307
  * @returns {Promise} Promise that is resolved when the navigation is finalized
@@ -324,7 +309,7 @@ sap.ui.define(
324
309
  */
325
310
  navTo: function(sRouteName, oParameters) {
326
311
  var sHash = this._oRouter.getURL(sRouteName, oParameters);
327
- return this.navToHash(sHash, false, oParameters.noPreservationCache);
312
+ return this.navToHash(sHash, false, oParameters.noPreservationCache, null, !oParameters.bIsStickyMode);
328
313
  },
329
314
 
330
315
  /**
@@ -432,6 +417,24 @@ sap.ui.define(
432
417
  this._bActivateRouteMatchSynchro = false;
433
418
  },
434
419
 
420
+ _extractKeysFromHash: function(sHash) {
421
+ if (sHash === undefined) {
422
+ sHash = "";
423
+ }
424
+ var sHashNoParams = sHash.split("?")[0]; // remove params
425
+ var aTokens = sHashNoParams.split("/");
426
+ var aKeys = [];
427
+
428
+ aTokens.forEach(function(sToken) {
429
+ var regexKey = /[^\(\)]+\([^\(\)]+\)/; // abc(def)
430
+ if (regexKey.test(sToken)) {
431
+ aKeys.push(sToken.split("(")[0]);
432
+ }
433
+ });
434
+
435
+ return aKeys;
436
+ },
437
+
435
438
  /**
436
439
  * Builds a state from a hash.
437
440
  *
@@ -441,22 +444,13 @@ sap.ui.define(
441
444
  * @ui5-restricted
442
445
  */
443
446
  _extractStateFromHash: function(sHash) {
444
- var oState = {
445
- keys: []
446
- };
447
-
448
- // Retrieve object keys
449
447
  if (sHash === undefined) {
450
448
  sHash = "";
451
449
  }
452
- var sHashNoParams = sHash.split("?")[0];
453
- var sTokens = sHashNoParams.split("/");
454
- sTokens.forEach(function(sToken) {
455
- var regexKey = /[^\(\)]+\([^\(\)]+\)/; // abc(def)
456
- if (regexKey.test(sToken)) {
457
- oState.keys.push(sToken.split("(")[0]);
458
- }
459
- });
450
+
451
+ var oState = {
452
+ keys: this._extractKeysFromHash(sHash)
453
+ };
460
454
 
461
455
  // Retrieve layout (if any)
462
456
  var aLayout = sHash.match(new RegExp("\\?.*" + enumURLParams.LAYOUTPARAM + "=([^&]*)"));
@@ -518,7 +512,6 @@ sap.ui.define(
518
512
  }
519
513
 
520
514
  // 3. Then pop all states until we find an ancestor of the new state, or we find a state that need to be preserved
521
- var oLastFocusControl;
522
515
  var oLastRemovedItem;
523
516
  while (this._oManagedHistory.length > 0) {
524
517
  var oTopState = this._oManagedHistory[this._oManagedHistory.length - 1];
@@ -527,13 +520,11 @@ sap.ui.define(
527
520
  this._compareCacheStates(oTopState, oNewState) !== enumState.ANCESTOR
528
521
  ) {
529
522
  // The top state is not an ancestor of oNewState and is not preserved --> we can pop it
530
- oLastFocusControl = oTopState.oLastFocusControl;
531
523
  oLastRemovedItem = this._oManagedHistory.pop();
532
524
  iPopCount++;
533
525
  } else if (oTopState.preserved && removeAppStateInHash(oTopState.hash) === removeAppStateInHash(oNewState.hash)) {
534
526
  // We try to add a state that is already in cache (due to preserved flag) but with a different iapp-state
535
527
  // --> we should delete the previous entry (it will be later replaced by the new one) and stop popping
536
- oLastFocusControl = oTopState.oLastFocusControl;
537
528
  oLastRemovedItem = this._oManagedHistory.pop();
538
529
  iPopCount++;
539
530
  oNewState.preserved = true;
@@ -565,7 +556,6 @@ sap.ui.define(
565
556
  }
566
557
 
567
558
  // 5. Now we can push the state at the top of the internal history
568
- oNewState.oLastFocusControl = oLastFocusControl;
569
559
  var bHasSameHash = oLastRemovedItem && oNewState.hash === oLastRemovedItem.hash;
570
560
  if (this._oManagedHistory.length === 0 || this._oManagedHistory[this._oManagedHistory.length - 1].hash !== oNewState.hash) {
571
561
  this._oManagedHistory.push(oNewState);
@@ -1,6 +1,6 @@
1
1
  /*!
2
2
  * SAPUI5
3
- * (c) Copyright 2009-2021 SAP SE. All rights reserved.
3
+ * (c) Copyright 2009-2022 SAP SE. All rights reserved.
4
4
  */
5
5
  sap.ui.define(["sap/base/Log", "sap/ui/base/Object"], function(Log, BaseObject) {
6
6
  "use strict";
@@ -1,6 +1,6 @@
1
1
  /*!
2
2
  * SAPUI5
3
- * (c) Copyright 2009-2021 SAP SE. All rights reserved.
3
+ * (c) Copyright 2009-2022 SAP SE. All rights reserved.
4
4
  */
5
5
  sap.ui.define(
6
6
  ["sap/ui/core/UIComponent", "sap/fe/core/CommonUtils", "sap/base/Log"],
@@ -63,6 +63,12 @@ sap.ui.define(
63
63
  */
64
64
  allowDeepLinking: {
65
65
  type: "boolean"
66
+ },
67
+ /**
68
+ * Defines the context path on the component that is refreshed when the app is restored using keep alive mode
69
+ */
70
+ refreshStrategyOnAppRestore: {
71
+ type: "object"
66
72
  }
67
73
  },
68
74
  events: {
@@ -96,11 +102,11 @@ sap.ui.define(
96
102
  return this.oAppComponent;
97
103
  },
98
104
 
99
- onPageReady: function(oLastFocusedControl) {
105
+ onPageReady: function(mParameters) {
100
106
  if (this.getRootControl() && this.getRootControl().getController() && this.getRootControl().getController().onPageReady) {
101
107
  this.getRootControl()
102
108
  .getController()
103
- .onPageReady(oLastFocusedControl);
109
+ .onPageReady(mParameters);
104
110
  }
105
111
  },
106
112
 
@@ -1,6 +1,6 @@
1
1
  /*!
2
2
  * SAPUI5
3
- * (c) Copyright 2009-2021 SAP SE. All rights reserved.
3
+ * (c) Copyright 2009-2022 SAP SE. All rights reserved.
4
4
  */
5
5
  sap.ui.define(["sap/base/Log", "sap/ui/base/Object", "sap/ui/model/json/JSONModel"], function(Log, BaseObject, JSONModel) {
6
6
  "use strict";