@sapui5/sap.fe.core 1.93.3 → 1.97.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +6 -6
- package/src/sap/fe/core/.library +1 -1
- package/src/sap/fe/core/AppComponent.js +8 -40
- package/src/sap/fe/core/BusyLocker.js +12 -0
- package/src/sap/fe/core/CommonUtils.js +224 -48
- package/src/sap/fe/core/ExtensionAPI.js +1 -1
- package/src/sap/fe/core/PageController.js +13 -2
- package/src/sap/fe/core/RouterProxy.js +52 -64
- package/src/sap/fe/core/TemplateComponent.js +8 -2
- package/src/sap/fe/core/TransactionHelper.js +210 -180
- package/src/sap/fe/core/actions/draft.js +13 -1
- package/src/sap/fe/core/actions/messageHandling.js +80 -4
- package/src/sap/fe/core/actions/operations.js +207 -68
- package/src/sap/fe/core/controllerextensions/EditFlow.js +82 -55
- package/src/sap/fe/core/controllerextensions/InternalEditFlow.js +13 -6
- package/src/sap/fe/core/controllerextensions/InternalIntentBasedNavigation.js +132 -23
- package/src/sap/fe/core/controllerextensions/InternalRouting.js +203 -214
- package/src/sap/fe/core/controllerextensions/KPIManagement.js +834 -170
- package/src/sap/fe/core/controllerextensions/KPIManagement.ts +890 -189
- package/src/sap/fe/core/controllerextensions/MessageHandler.js +222 -102
- package/src/sap/fe/core/controllerextensions/PageReady.js +48 -33
- package/src/sap/fe/core/controllerextensions/PageReady.ts +49 -14
- package/src/sap/fe/core/controllerextensions/Paginator.js +150 -0
- package/src/sap/fe/core/controllerextensions/Placeholder.js +133 -270
- package/src/sap/fe/core/controllerextensions/Share.js +12 -9
- package/src/sap/fe/core/controllerextensions/SideEffects.js +5 -6
- package/src/sap/fe/core/controllerextensions/SideEffects.ts +13 -12
- package/src/sap/fe/core/controllerextensions/ViewState.js +202 -8
- package/src/sap/fe/core/controls/ActionParameterDialog.fragment.xml +39 -34
- package/src/sap/fe/core/controls/ActionParameterDialogValueHelp.fragment.xml +35 -0
- package/src/sap/fe/core/controls/ActionPartial.fragment.xml +1 -1
- package/src/sap/fe/core/controls/CustomQuickViewPage.js +109 -108
- package/src/sap/fe/core/controls/MultiValueParameterDelegate.js +45 -0
- package/src/sap/fe/core/controls/filterbar/FilterContainer.js +15 -4
- package/src/sap/fe/core/controls/filterbar/VisualFilter.js +250 -94
- package/src/sap/fe/core/controls/filterbar/VisualFilterContainer.js +129 -135
- package/src/sap/fe/core/controls/filterbar/utils/VisualFilterUtils.js +325 -0
- package/src/sap/fe/core/controls/filterbar.d.js +8 -0
- package/src/sap/fe/core/controls/filterbar.d.ts +0 -0
- package/src/sap/fe/core/converters/ConverterContext.js +19 -5
- package/src/sap/fe/core/converters/ConverterContext.ts +13 -3
- package/src/sap/fe/core/converters/ManifestSettings.js +2 -1
- package/src/sap/fe/core/converters/ManifestSettings.ts +13 -3
- package/src/sap/fe/core/converters/ManifestWrapper.js +9 -9
- package/src/sap/fe/core/converters/MetaModelConverter.js +867 -871
- package/src/sap/fe/core/converters/MetaModelConverter.ts +772 -827
- package/src/sap/fe/core/converters/TemplateConverter.js +4 -4
- package/src/sap/fe/core/converters/annotations/DataField.js +57 -7
- package/src/sap/fe/core/converters/annotations/DataField.ts +52 -2
- package/src/sap/fe/core/converters/common/AnnotationConverter.js +146 -85
- package/src/sap/fe/core/converters/controls/Common/Action.js +61 -56
- package/src/sap/fe/core/converters/controls/Common/Action.ts +54 -39
- package/src/sap/fe/core/converters/controls/Common/Chart.js +101 -9
- package/src/sap/fe/core/converters/controls/Common/Chart.ts +100 -5
- package/src/sap/fe/core/converters/controls/Common/Criticality.js +1 -1
- package/src/sap/fe/core/converters/controls/Common/DataVisualization.js +15 -16
- package/src/sap/fe/core/converters/controls/Common/DataVisualization.ts +16 -30
- package/src/sap/fe/core/converters/controls/Common/Form.js +77 -29
- package/src/sap/fe/core/converters/controls/Common/Form.ts +79 -21
- package/src/sap/fe/core/converters/controls/Common/KPI.js +287 -109
- package/src/sap/fe/core/converters/controls/Common/KPI.ts +314 -139
- package/src/sap/fe/core/converters/controls/Common/Table.js +521 -166
- package/src/sap/fe/core/converters/controls/Common/Table.ts +519 -115
- package/src/sap/fe/core/converters/controls/ListReport/FilterBar.js +487 -0
- package/src/sap/fe/core/converters/controls/ListReport/FilterBar.ts +541 -0
- package/src/sap/fe/core/converters/controls/ListReport/VisualFilters.js +364 -0
- package/src/sap/fe/core/converters/controls/ListReport/VisualFilters.ts +338 -0
- package/src/sap/fe/core/converters/controls/ObjectPage/Avatar.js +74 -0
- package/src/sap/fe/core/converters/controls/ObjectPage/Avatar.ts +50 -0
- package/src/sap/fe/core/converters/controls/ObjectPage/HeaderFacet.js +11 -11
- package/src/sap/fe/core/converters/controls/ObjectPage/SubSection.js +47 -35
- package/src/sap/fe/core/converters/controls/ObjectPage/SubSection.ts +45 -29
- package/src/sap/fe/core/converters/helpers/Aggregation.js +31 -32
- package/src/sap/fe/core/converters/helpers/Aggregation.ts +26 -27
- package/src/sap/fe/core/converters/helpers/BindingHelper.js +27 -2
- package/src/sap/fe/core/converters/helpers/BindingHelper.ts +22 -2
- package/src/sap/fe/core/converters/helpers/ConfigurableObject.js +1 -1
- package/src/sap/fe/core/converters/helpers/ID.js +9 -3
- package/src/sap/fe/core/converters/helpers/ID.ts +6 -3
- package/src/sap/fe/core/converters/helpers/IssueManager.js +5 -4
- package/src/sap/fe/core/converters/helpers/IssueManager.ts +4 -3
- package/src/sap/fe/core/converters/helpers/Key.js +3 -3
- package/src/sap/fe/core/converters/helpers/SelectionVariantHelper.js +11 -6
- package/src/sap/fe/core/converters/helpers/SelectionVariantHelper.ts +9 -5
- package/src/sap/fe/core/converters/objectPage/FormMenuActions.js +18 -5
- package/src/sap/fe/core/converters/objectPage/FormMenuActions.ts +14 -14
- package/src/sap/fe/core/converters/objectPage/HeaderAndFooterAction.js +91 -20
- package/src/sap/fe/core/converters/objectPage/HeaderAndFooterAction.ts +77 -5
- package/src/sap/fe/core/converters/templates/ListReportConverter.js +87 -714
- package/src/sap/fe/core/converters/templates/ListReportConverter.ts +85 -812
- package/src/sap/fe/core/converters/templates/ObjectPageConverter.js +106 -17
- package/src/sap/fe/core/converters/templates/ObjectPageConverter.ts +121 -16
- package/src/sap/fe/core/designtime/AppComponent.designtime.js +2 -1
- package/src/sap/fe/core/formatters/CriticalityFormatter.js +1 -1
- package/src/sap/fe/core/formatters/FPMFormatter.js +1 -1
- package/src/sap/fe/core/formatters/FPMFormatter.ts +8 -3
- package/src/sap/fe/core/formatters/KPIFormatter.js +1 -1
- package/src/sap/fe/core/formatters/TableFormatter.js +27 -4
- package/src/sap/fe/core/formatters/TableFormatter.ts +20 -3
- package/src/sap/fe/core/formatters/TableFormatterTypes.js +1 -1
- package/src/sap/fe/core/formatters/ValueFormatter.js +1 -1
- package/src/sap/fe/core/fpm/Component.js +1 -1
- package/src/sap/fe/core/helpers/AnnotationEnum.js +3 -3
- package/src/sap/fe/core/helpers/BindingExpression.js +6 -6
- package/src/sap/fe/core/helpers/ClassSupport.js +4 -4
- package/src/sap/fe/core/helpers/ExcelFormatHelper.js +0 -2
- package/src/sap/fe/core/helpers/KeepAliveHelper.js +211 -0
- package/src/sap/fe/core/helpers/KeepAliveHelper.ts +202 -0
- package/src/sap/fe/core/helpers/KeepAliveRefreshTypes.js +32 -0
- package/src/sap/fe/core/helpers/KeepAliveRefreshTypes.ts +36 -0
- package/src/sap/fe/core/helpers/ModelHelper.js +78 -0
- package/src/sap/fe/core/helpers/PasteHelper.js +6 -0
- package/src/sap/fe/core/helpers/SemanticKeyHelper.js +2 -2
- package/src/sap/fe/core/helpers/StableIdHelper.js +1 -1
- package/src/sap/fe/core/helpers/StableIdHelper.ts +1 -1
- package/src/sap/fe/core/jsx-runtime/jsx.js +2 -2
- package/src/sap/fe/core/jsx-runtime/jsxs.js +1 -1
- package/src/sap/fe/core/library.js +1 -1
- package/src/sap/fe/core/messagebundle.properties +45 -2
- package/src/sap/fe/core/messagebundle_ar.properties +53 -1
- package/src/sap/fe/core/messagebundle_bg.properties +52 -0
- package/src/sap/fe/core/messagebundle_ca.properties +54 -2
- package/src/sap/fe/core/messagebundle_cs.properties +52 -0
- package/src/sap/fe/core/messagebundle_cy.properties +52 -0
- package/src/sap/fe/core/messagebundle_da.properties +53 -1
- package/src/sap/fe/core/messagebundle_de.properties +55 -3
- package/src/sap/fe/core/messagebundle_el.properties +53 -1
- package/src/sap/fe/core/messagebundle_en.properties +52 -0
- package/src/sap/fe/core/messagebundle_en_GB.properties +53 -1
- package/src/sap/fe/core/messagebundle_en_US_sappsd.properties +49 -1
- package/src/sap/fe/core/messagebundle_en_US_saprigi.properties +53 -1
- package/src/sap/fe/core/messagebundle_en_US_saptrc.properties +53 -1
- package/src/sap/fe/core/messagebundle_es.properties +60 -8
- package/src/sap/fe/core/messagebundle_es_MX.properties +55 -3
- package/src/sap/fe/core/messagebundle_et.properties +52 -0
- package/src/sap/fe/core/messagebundle_fi.properties +52 -0
- package/src/sap/fe/core/messagebundle_fr.properties +61 -9
- package/src/sap/fe/core/messagebundle_fr_CA.properties +52 -0
- package/src/sap/fe/core/messagebundle_hi.properties +53 -1
- package/src/sap/fe/core/messagebundle_hr.properties +53 -1
- package/src/sap/fe/core/messagebundle_hu.properties +52 -0
- package/src/sap/fe/core/messagebundle_id.properties +54 -2
- package/src/sap/fe/core/messagebundle_it.properties +53 -1
- package/src/sap/fe/core/messagebundle_iw.properties +54 -2
- package/src/sap/fe/core/messagebundle_ja.properties +62 -10
- package/src/sap/fe/core/messagebundle_kk.properties +53 -1
- package/src/sap/fe/core/messagebundle_ko.properties +53 -1
- package/src/sap/fe/core/messagebundle_lt.properties +53 -1
- package/src/sap/fe/core/messagebundle_lv.properties +53 -1
- package/src/sap/fe/core/messagebundle_ms.properties +53 -1
- package/src/sap/fe/core/messagebundle_nl.properties +57 -5
- package/src/sap/fe/core/messagebundle_no.properties +54 -2
- package/src/sap/fe/core/messagebundle_pl.properties +53 -1
- package/src/sap/fe/core/messagebundle_pt.properties +54 -2
- package/src/sap/fe/core/messagebundle_pt_PT.properties +53 -1
- package/src/sap/fe/core/messagebundle_ro.properties +53 -1
- package/src/sap/fe/core/messagebundle_ru.properties +53 -1
- package/src/sap/fe/core/messagebundle_sh.properties +53 -1
- package/src/sap/fe/core/messagebundle_sk.properties +52 -0
- package/src/sap/fe/core/messagebundle_sl.properties +53 -1
- package/src/sap/fe/core/messagebundle_sv.properties +53 -1
- package/src/sap/fe/core/messagebundle_th.properties +52 -0
- package/src/sap/fe/core/messagebundle_tr.properties +52 -0
- package/src/sap/fe/core/messagebundle_uk.properties +52 -0
- package/src/sap/fe/core/messagebundle_vi.properties +53 -1
- package/src/sap/fe/core/messagebundle_zh_CN.properties +53 -1
- package/src/sap/fe/core/messagebundle_zh_TW.properties +53 -1
- package/src/sap/fe/core/services/AsyncComponentServiceFactory.js +5 -5
- package/src/sap/fe/core/services/EnvironmentServiceFactory.js +5 -5
- package/src/sap/fe/core/services/RoutingServiceFactory.js +154 -78
- package/src/sap/fe/core/services/ShellServicesFactory.js +9 -9
- package/src/sap/fe/core/services/SideEffectsServiceFactory.js +11 -12
- package/src/sap/fe/core/services/TemplatedViewServiceFactory.js +12 -2
- package/src/sap/fe/core/support/AnnotationIssue.support.js +2 -4
- package/src/sap/fe/core/support/CollectionFacetMissingID.support.js +2 -4
- package/src/sap/fe/core/support/CollectionFacetUnsupportedLevel.support.js +2 -4
- package/src/sap/fe/core/support/CommonHelper.js +2 -4
- package/src/sap/fe/core/support/Diagnostics.js +1 -1
- package/src/sap/fe/core/templating/CriticalityFormatters.js +4 -4
- package/src/sap/fe/core/templating/DataFieldFormatters.js +1 -1
- package/src/sap/fe/core/templating/DataModelPathHelper.js +54 -6
- package/src/sap/fe/core/templating/DataModelPathHelper.ts +54 -4
- package/src/sap/fe/core/templating/EntitySetHelper.js +86 -3
- package/src/sap/fe/core/templating/EntitySetHelper.ts +44 -0
- package/src/sap/fe/core/templating/FieldControlHelper.js +1 -1
- package/src/sap/fe/core/templating/FilterHelper.js +23 -5
- package/src/sap/fe/core/templating/FilterHelper.ts +15 -1
- package/src/sap/fe/core/templating/FilterTemplating.js +1 -1
- package/src/sap/fe/core/templating/PropertyFormatters.js +1 -1
- package/src/sap/fe/core/templating/PropertyHelper.js +8 -8
- package/src/sap/fe/core/templating/UIFormatters.js +72 -4
- package/src/sap/fe/core/templating/UIFormatters.ts +98 -3
- package/src/sap/fe/core/type/Email.js +1 -1
|
@@ -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,31 @@ 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
|
|
192
|
+
* @param {boolean} bForceFocus If set to true, the logic to set the focus once the navigation is finalized will be triggered (onPageReady)
|
|
183
193
|
* @returns {Promise} Promise that is resolved when the navigation is finalized
|
|
184
194
|
* @ui5-restricted
|
|
185
195
|
*/
|
|
186
|
-
navToHash: function(sHash, bPreserveHistory, bDisablePreservationCache) {
|
|
196
|
+
navToHash: function(sHash, bPreserveHistory, bDisablePreservationCache, bForceFocus) {
|
|
187
197
|
var that = this;
|
|
188
198
|
|
|
189
199
|
if (this._oRouteMatchSynchronization) {
|
|
190
200
|
return this._oRouteMatchSynchronization.waitFor().then(function() {
|
|
191
201
|
that._oRouteMatchSynchronization = null;
|
|
192
|
-
return that._internalNavToHash(sHash, bPreserveHistory, bDisablePreservationCache);
|
|
202
|
+
return that._internalNavToHash(sHash, bPreserveHistory, bDisablePreservationCache, bForceFocus);
|
|
193
203
|
});
|
|
194
204
|
} else {
|
|
195
205
|
if (this._bActivateRouteMatchSynchro) {
|
|
196
206
|
this.waitForRouteMatchBeforeNavigation();
|
|
197
207
|
}
|
|
198
|
-
return that._internalNavToHash(sHash, bPreserveHistory, bDisablePreservationCache);
|
|
208
|
+
return that._internalNavToHash(sHash, bPreserveHistory, bDisablePreservationCache, bForceFocus);
|
|
199
209
|
}
|
|
200
210
|
},
|
|
201
211
|
|
|
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
|
-
|
|
212
|
+
_internalNavToHash: function(sHash, bPreserveHistory, bDisablePreservationCache, bForceFocus) {
|
|
214
213
|
// Add the app state in the hash if needed
|
|
215
214
|
if (this.fclEnabled && this.sIAppStateKey && !findAppStateInHash(sHash)) {
|
|
216
215
|
sHash = setAppStateInHash(sHash, this.sIAppStateKey);
|
|
217
216
|
}
|
|
218
|
-
var oNewState = this._extractStateFromHash(sHash);
|
|
219
217
|
|
|
220
218
|
if (!this.checkHashWithGuard(sHash)) {
|
|
221
219
|
if (!this.oResourceBundle) {
|
|
@@ -230,11 +228,24 @@ sap.ui.define(
|
|
|
230
228
|
}
|
|
231
229
|
this.bIsGuardCrossAllowed = true;
|
|
232
230
|
}
|
|
231
|
+
|
|
232
|
+
// In case the navigation will cause a new view to be displayed, we force the focus
|
|
233
|
+
// I.e. if the keys for the hash we're navigating to is a superset of the current hash keys.
|
|
234
|
+
var oNewState = this._extractStateFromHash(sHash);
|
|
235
|
+
if (!this._bForceFocus) {
|
|
236
|
+
// If the focus was already forced, keep it
|
|
237
|
+
var aCurrentHashKeys = this._extractKeysFromHash(this.getHash());
|
|
238
|
+
this._bForceFocus =
|
|
239
|
+
bForceFocus ||
|
|
240
|
+
(aCurrentHashKeys.length < oNewState.keys.length &&
|
|
241
|
+
aCurrentHashKeys.every(function(key, index) {
|
|
242
|
+
return key === oNewState.keys[index];
|
|
243
|
+
}));
|
|
244
|
+
}
|
|
245
|
+
|
|
233
246
|
var oHistoryAction = this._pushNewState(oNewState, false, bPreserveHistory, bDisablePreservationCache);
|
|
234
247
|
|
|
235
|
-
return this._rebuildBrowserHistory(oHistoryAction, false)
|
|
236
|
-
that.storeFocusForHash(sLastFocusControlId, sLastFocusInfo, shashBeforeRoutechanged);
|
|
237
|
-
});
|
|
248
|
+
return this._rebuildBrowserHistory(oHistoryAction, false);
|
|
238
249
|
},
|
|
239
250
|
|
|
240
251
|
/**
|
|
@@ -258,34 +269,6 @@ sap.ui.define(
|
|
|
258
269
|
}
|
|
259
270
|
},
|
|
260
271
|
|
|
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
272
|
/**
|
|
290
273
|
* Navigates back in the history.
|
|
291
274
|
*
|
|
@@ -432,6 +415,24 @@ sap.ui.define(
|
|
|
432
415
|
this._bActivateRouteMatchSynchro = false;
|
|
433
416
|
},
|
|
434
417
|
|
|
418
|
+
_extractKeysFromHash: function(sHash) {
|
|
419
|
+
if (sHash === undefined) {
|
|
420
|
+
sHash = "";
|
|
421
|
+
}
|
|
422
|
+
var sHashNoParams = sHash.split("?")[0]; // remove params
|
|
423
|
+
var aTokens = sHashNoParams.split("/");
|
|
424
|
+
var aKeys = [];
|
|
425
|
+
|
|
426
|
+
aTokens.forEach(function(sToken) {
|
|
427
|
+
var regexKey = /[^\(\)]+\([^\(\)]+\)/; // abc(def)
|
|
428
|
+
if (regexKey.test(sToken)) {
|
|
429
|
+
aKeys.push(sToken.split("(")[0]);
|
|
430
|
+
}
|
|
431
|
+
});
|
|
432
|
+
|
|
433
|
+
return aKeys;
|
|
434
|
+
},
|
|
435
|
+
|
|
435
436
|
/**
|
|
436
437
|
* Builds a state from a hash.
|
|
437
438
|
*
|
|
@@ -441,22 +442,13 @@ sap.ui.define(
|
|
|
441
442
|
* @ui5-restricted
|
|
442
443
|
*/
|
|
443
444
|
_extractStateFromHash: function(sHash) {
|
|
444
|
-
var oState = {
|
|
445
|
-
keys: []
|
|
446
|
-
};
|
|
447
|
-
|
|
448
|
-
// Retrieve object keys
|
|
449
445
|
if (sHash === undefined) {
|
|
450
446
|
sHash = "";
|
|
451
447
|
}
|
|
452
|
-
|
|
453
|
-
var
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
if (regexKey.test(sToken)) {
|
|
457
|
-
oState.keys.push(sToken.split("(")[0]);
|
|
458
|
-
}
|
|
459
|
-
});
|
|
448
|
+
|
|
449
|
+
var oState = {
|
|
450
|
+
keys: this._extractKeysFromHash(sHash)
|
|
451
|
+
};
|
|
460
452
|
|
|
461
453
|
// Retrieve layout (if any)
|
|
462
454
|
var aLayout = sHash.match(new RegExp("\\?.*" + enumURLParams.LAYOUTPARAM + "=([^&]*)"));
|
|
@@ -518,7 +510,6 @@ sap.ui.define(
|
|
|
518
510
|
}
|
|
519
511
|
|
|
520
512
|
// 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
513
|
var oLastRemovedItem;
|
|
523
514
|
while (this._oManagedHistory.length > 0) {
|
|
524
515
|
var oTopState = this._oManagedHistory[this._oManagedHistory.length - 1];
|
|
@@ -527,13 +518,11 @@ sap.ui.define(
|
|
|
527
518
|
this._compareCacheStates(oTopState, oNewState) !== enumState.ANCESTOR
|
|
528
519
|
) {
|
|
529
520
|
// The top state is not an ancestor of oNewState and is not preserved --> we can pop it
|
|
530
|
-
oLastFocusControl = oTopState.oLastFocusControl;
|
|
531
521
|
oLastRemovedItem = this._oManagedHistory.pop();
|
|
532
522
|
iPopCount++;
|
|
533
523
|
} else if (oTopState.preserved && removeAppStateInHash(oTopState.hash) === removeAppStateInHash(oNewState.hash)) {
|
|
534
524
|
// We try to add a state that is already in cache (due to preserved flag) but with a different iapp-state
|
|
535
525
|
// --> we should delete the previous entry (it will be later replaced by the new one) and stop popping
|
|
536
|
-
oLastFocusControl = oTopState.oLastFocusControl;
|
|
537
526
|
oLastRemovedItem = this._oManagedHistory.pop();
|
|
538
527
|
iPopCount++;
|
|
539
528
|
oNewState.preserved = true;
|
|
@@ -565,7 +554,6 @@ sap.ui.define(
|
|
|
565
554
|
}
|
|
566
555
|
|
|
567
556
|
// 5. Now we can push the state at the top of the internal history
|
|
568
|
-
oNewState.oLastFocusControl = oLastFocusControl;
|
|
569
557
|
var bHasSameHash = oLastRemovedItem && oNewState.hash === oLastRemovedItem.hash;
|
|
570
558
|
if (this._oManagedHistory.length === 0 || this._oManagedHistory[this._oManagedHistory.length - 1].hash !== oNewState.hash) {
|
|
571
559
|
this._oManagedHistory.push(oNewState);
|
|
@@ -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(
|
|
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(
|
|
109
|
+
.onPageReady(mParameters);
|
|
104
110
|
}
|
|
105
111
|
},
|
|
106
112
|
|