@sapui5/sap.suite.ui.generic.template 1.120.41 → 1.120.43

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 (43) hide show
  1. package/package.json +1 -1
  2. package/src/sap/suite/ui/generic/template/.library +1 -1
  3. package/src/sap/suite/ui/generic/template/AnalyticalListPage/i18n/i18n_id.properties +2 -2
  4. package/src/sap/suite/ui/generic/template/AnalyticalListPage/i18n/i18n_it.properties +2 -2
  5. package/src/sap/suite/ui/generic/template/AnalyticalListPage/manifest.json +1 -1
  6. package/src/sap/suite/ui/generic/template/Canvas/manifest.json +1 -1
  7. package/src/sap/suite/ui/generic/template/ListReport/controller/ControllerImplementation.js +4 -2
  8. package/src/sap/suite/ui/generic/template/ListReport/controller/IappStateHandler.js +18 -8
  9. package/src/sap/suite/ui/generic/template/ListReport/i18n/i18n_id.properties +1 -1
  10. package/src/sap/suite/ui/generic/template/ListReport/manifest.json +1 -1
  11. package/src/sap/suite/ui/generic/template/ListReport/view/fragments/SmartChart.fragment.xml +2 -1
  12. package/src/sap/suite/ui/generic/template/ListReport/view/fragments/SmartTable.fragment.xml +3 -2
  13. package/src/sap/suite/ui/generic/template/ObjectPage/controller/ControllerImplementation.js +14 -4
  14. package/src/sap/suite/ui/generic/template/ObjectPage/controller/RelatedAppsHandler.js +27 -32
  15. package/src/sap/suite/ui/generic/template/ObjectPage/i18n/i18n_cnr.properties +1 -1
  16. package/src/sap/suite/ui/generic/template/ObjectPage/i18n/i18n_mk.properties +1 -1
  17. package/src/sap/suite/ui/generic/template/ObjectPage/i18n/i18n_sh.properties +1 -1
  18. package/src/sap/suite/ui/generic/template/ObjectPage/i18n/i18n_sl.properties +3 -3
  19. package/src/sap/suite/ui/generic/template/ObjectPage/i18n/i18n_sr.properties +1 -1
  20. package/src/sap/suite/ui/generic/template/ObjectPage/manifest.json +1 -1
  21. package/src/sap/suite/ui/generic/template/ObjectPage/view/fragments/SmartChart.fragment.xml +1 -0
  22. package/src/sap/suite/ui/generic/template/ObjectPage/view/fragments/SmartTable.fragment.xml +1 -0
  23. package/src/sap/suite/ui/generic/template/QuickCreate/manifest.json +1 -1
  24. package/src/sap/suite/ui/generic/template/QuickView/manifest.json +1 -1
  25. package/src/sap/suite/ui/generic/template/detailTemplates/detailUtils.js +18 -1
  26. package/src/sap/suite/ui/generic/template/genericUtilities/ControlStateWrapperFactory.js +109 -68
  27. package/src/sap/suite/ui/generic/template/genericUtilities/controlHelper.js +30 -27
  28. package/src/sap/suite/ui/generic/template/genericUtilities/controlStateWrapperFactory/DynamicPageWrapper.js +19 -51
  29. package/src/sap/suite/ui/generic/template/genericUtilities/controlStateWrapperFactory/ObjectPageLayoutWrapper.js +10 -32
  30. package/src/sap/suite/ui/generic/template/genericUtilities/controlStateWrapperFactory/PreliminaryWrapper.js +151 -0
  31. package/src/sap/suite/ui/generic/template/genericUtilities/controlStateWrapperFactory/SearchFieldWrapper.js +8 -30
  32. package/src/sap/suite/ui/generic/template/genericUtilities/controlStateWrapperFactory/SmartFilterBarWrapper.js +76 -99
  33. package/src/sap/suite/ui/generic/template/genericUtilities/controlStateWrapperFactory/SmartTableChartCommon.js +100 -92
  34. package/src/sap/suite/ui/generic/template/genericUtilities/controlStateWrapperFactory/SmartTableWrapper.js +10 -2
  35. package/src/sap/suite/ui/generic/template/genericUtilities/controlStateWrapperFactory/SmartVariantManagementWrapper.js +90 -81
  36. package/src/sap/suite/ui/generic/template/lib/AppComponent.js +5 -1
  37. package/src/sap/suite/ui/generic/template/lib/CommonEventHandlers.js +4 -1
  38. package/src/sap/suite/ui/generic/template/lib/i18n/i18n_fi.properties +2 -2
  39. package/src/sap/suite/ui/generic/template/lib/i18n/i18n_fr.properties +2 -2
  40. package/src/sap/suite/ui/generic/template/lib/i18n/i18n_nl.properties +1 -1
  41. package/src/sap/suite/ui/generic/template/lib/i18n/i18n_ru.properties +5 -5
  42. package/src/sap/suite/ui/generic/template/lib/navigation/NavigationController.js +1 -1
  43. package/src/sap/suite/ui/generic/template/library.js +1 -1
@@ -4,40 +4,64 @@ sap.ui.define([
4
4
 
5
5
  /**
6
6
  * Constructor for SmartTableChartCommon
7
- * ...
8
- * @param {object} mParams
9
- * @param mParams.oCustomFiltersWrapper - wrapper for custom filters (from SFB point of view)
10
- * (currently containing: generic (currently only editState), app extension, and adaptation extension - but this is knowledge of LR, i.e. of iAppStateHandler, not of SFB)
7
+ * @param {sap.ui.core.Control} oControl - The SmartTable or SmartChart control
8
+ * @param {object} oController - The controller instance
9
+ * @param {object} oFactory - The ControlStateWrapperFactory instance
10
+ * @param {string} sInitializationEvent - The initialization event name (e.g., "initialise")
11
+ * @param {object} [mExtensions] - Optional extension functions for control-specific state handling
12
+ * @param {function} [mExtensions.fnExtendGetUiState] - Function to extend UiState during getState
13
+ * Called with (oStateUiState, oControlUiState) where modifications to oStateUiState add to the state
14
+ * @param {function} [mExtensions.fnExtendSetUiState] - Function to extend UiState during setState
15
+ * Called with (oStateUiState, oControlUiState) where oStateUiState contains the state to apply
11
16
  * @returns {object}
12
17
  */
13
18
 
14
19
  // deals with state of SFB itself, without SVM (see SmartVariantManagementWrapper) and go-button
15
20
  // (does not contain a state from SFB point of view - however, we remember whether it was pressed once
16
21
  // to restore data - this information is not considered being part of SFB)
17
- function SmartTableChartCommon(vTarget, oController, oFactory, sInitializationEvent) {
18
- var oSmartControl, oVariantManagementControl, bVariantManagementActive;
19
- var oControlAssignedResolve, oPreliminaryState, bSmartControlInitialized;
22
+ function SmartTableChartCommon(oControl, oController, oFactory, sInitializationEvent, mExtensions) {
23
+ var oSmartControl = oControl;
24
+ var oVariantManagementControl, bVariantManagementActive;
20
25
  var oSmartControlStateWrapper;
21
26
  var oVariantManagementStateWrapper;
27
+ var oVariantManagementInitializedResolve;
28
+ var fnResolveReady;
22
29
 
23
- var oControlAssignedPromise = new Promise(function (resolve) {
24
- oControlAssignedResolve = resolve;
30
+ var oVariantManagementInitializedPromise = new Promise(function(resolve){
31
+ oVariantManagementInitializedResolve = resolve;
25
32
  });
26
33
 
27
- if (typeof vTarget !== "string") {
28
- fnSetControl(vTarget);
34
+ var oReadyPromise = new Promise(function(resolve) {
35
+ fnResolveReady = resolve;
36
+ });
37
+
38
+ // Initialize control state wrapper and check if control is already initialized
39
+ oSmartControlStateWrapper = getControlWrapper(oSmartControl);
40
+ if (!oSmartControl.isInitialised()) {
41
+ // In case Smart Chart/Table is not yet initialized
42
+ // listen to the initialize event & then initialize the wrapper
43
+ oSmartControl.attachEvent(sInitializationEvent, fnControlInitialized);
44
+ } else {
45
+ fnControlInitialized();
29
46
  }
30
47
 
31
48
  // creates a simple wrapper for a SmartTable or SmartChart (a control using UIState) (ignoring initialization and vm)
32
49
  function getControlWrapper(oControl) {
33
50
  var bIsApplying = false; // avoid forwarding change event when caused by us applying a state
34
51
  function fnGetState() {
35
- var oUiState = oControl.getUiState(); // unfortunately not serializable, but a managed object
52
+ var oControlUiState = oControl.getUiState(); // unfortunately not serializable, but a managed object
53
+ var oStateUiState = {
54
+ oPresentationVariant: oControlUiState.getPresentationVariant(),
55
+ oSelectionVariant: oControlUiState.getSelectionVariant()
56
+ };
57
+
58
+ // Allow extension to add control-specific properties (e.g., tableSettings for SmartTable)
59
+ if (mExtensions && mExtensions.fnExtendGetUiState) {
60
+ mExtensions.fnExtendGetUiState(oStateUiState, oControlUiState);
61
+ }
62
+
36
63
  return {
37
- oUiState: {
38
- oPresentationVariant: oUiState.getPresentationVariant(),
39
- oSelectionVariant: oUiState.getSelectionVariant()
40
- }
64
+ oUiState: oStateUiState
41
65
  };
42
66
  }
43
67
 
@@ -52,11 +76,17 @@ sap.ui.define([
52
76
  bIsApplying = true;
53
77
  // don't create UiState (managed object) from scratch, but fetch it from control and only apply known properties from state - thus, if any other properties would be added, we don't
54
78
  // interfere with them
55
- var oUiState = oControl.getUiState();
56
- if (!oUiState.getProperty("variantName")){
57
- oUiState.setPresentationVariant(oState.oUiState.oPresentationVariant);
58
- oUiState.setSelectionVariant(oState.oUiState.oSelectionVariant);
59
- oControl.setUiState(oUiState);
79
+ var oControlUiState = oControl.getUiState();
80
+ if (!oControlUiState.getProperty("variantName")){
81
+ oControlUiState.setPresentationVariant(oState.oUiState.oPresentationVariant);
82
+ oControlUiState.setSelectionVariant(oState.oUiState.oSelectionVariant);
83
+
84
+ // Allow extension to set control-specific properties (e.g., tableSettings for SmartTable)
85
+ if (mExtensions && mExtensions.fnExtendSetUiState) {
86
+ mExtensions.fnExtendSetUiState(oState.oUiState, oControlUiState);
87
+ }
88
+
89
+ oControl.setUiState(oControlUiState);
60
90
  }
61
91
  bIsApplying = false;
62
92
  } else {
@@ -82,77 +112,59 @@ sap.ui.define([
82
112
  getState: fnGetState,
83
113
  setState: fnSetState,
84
114
  getLocalId: fnGetLocalId,
85
- bVMConnection: false,
86
- attachStateChanged: fnAttachStateChanged
115
+ bVMConnection: oControl && oControl.getSmartVariant && !!oControl.getSmartVariant(),
116
+ attachStateChanged: fnAttachStateChanged,
117
+ onAfterVariantInitialise: oVariantManagementInitializedResolve
87
118
  };
88
119
  }
89
120
 
90
121
  function fnGetState() {
91
- if (bSmartControlInitialized) {
92
- if (oVariantManagementStateWrapper) {
93
- // oVariantManagementStateWrapper would be undefined only in cases SmartControl is not yet initialized
94
- // or VariantManagement is not enabled.
95
- return oVariantManagementStateWrapper.getState();
96
- }
97
-
98
- if (oSmartControlStateWrapper && !bVariantManagementActive) {
99
- // VariantManagement is not turned on & SmartControlStateWrapper instance
100
- return oSmartControlStateWrapper.getState();
101
- }
122
+ if (oVariantManagementStateWrapper) {
123
+ // Variant management is active
124
+ return oVariantManagementStateWrapper.getState();
102
125
  }
103
126
 
104
- // Control is not available and StateWrapper is not initialized
105
- return oPreliminaryState;
127
+ // No variant management - return control state directly
128
+ return oSmartControlStateWrapper.getState();
106
129
  }
107
130
 
108
131
  function fnSetState(oState) {
109
- oPreliminaryState = oState;
110
- oControlAssignedPromise.then(function () {
111
- // map legacy states - before separating VM state from state of managed control, inner state information
112
- // (presentation variant and selection variant) were put as oUiState on the same level as VM state
113
- // information (variant id and dirty indicator), now they are contained in map managedControlStates
114
- if (oState){
115
- if (oState.oUiState && !oState.managedControlStates) {
116
- oState.managedControlStates = Object.create(null);
117
- oState.managedControlStates[oSmartControlStateWrapper.getLocalId()] = {oUiState: oState.oUiState};
118
- }
119
- if (oState.bVariantModified !== undefined) {
120
- oState.modified = oState.bVariantModified;
121
- }
122
- if (oState.sVariantId !== undefined) {
123
- oState.variantId = oState.sVariantId;
124
- }
125
- }
126
-
132
+ if (!oState) {
133
+ // If no state provided, set standard variant on control
127
134
  if (bVariantManagementActive) {
128
- // In case VariantManagement is configured
129
- oVariantManagementStateWrapper.setState(oPreliminaryState);
130
- return;
135
+ oVariantManagementStateWrapper.setState(oState);
136
+ } else {
137
+ oSmartControlStateWrapper.setState(oState);
131
138
  }
132
-
133
- // SmartTable/Chart shall be used
134
- oSmartControlStateWrapper.setState(oPreliminaryState);
135
- });
136
- }
137
-
138
- function fnSetControl(oControl) {
139
- oSmartControl = oControl;
140
- oSmartControlStateWrapper = getControlWrapper(oSmartControl);
141
- if (!oSmartControl.isInitialised()) {
142
- // In case Smart Chart/Table is not yet initialized
143
- // listen to the initialize event & then resolve the control
144
- oSmartControl.attachEvent(sInitializationEvent, fnControlInitialized);
145
139
  return;
146
140
  }
147
141
 
148
- fnControlInitialized();
142
+ // Map legacy states - before separating VM state from state of managed control, inner state information
143
+ // (presentation variant and selection variant) were put as oUiState on the same level as VM state
144
+ // information (variant id and dirty indicator), now they are contained in map managedControlStates
145
+ if (oState.oUiState && !oState.managedControlStates) {
146
+ oState.managedControlStates = Object.create(null);
147
+ oState.managedControlStates[oSmartControlStateWrapper.getLocalId()] = {oUiState: oState.oUiState};
148
+ }
149
+ if (oState.bVariantModified !== undefined) {
150
+ oState.modified = oState.bVariantModified;
151
+ }
152
+ if (oState.sVariantId !== undefined) {
153
+ oState.variantId = oState.sVariantId;
154
+ }
155
+
156
+ if (bVariantManagementActive) {
157
+ // In case VariantManagement is configured
158
+ oVariantManagementStateWrapper.setState(oState);
159
+ } else {
160
+ // SmartTable/Chart shall be used
161
+ oSmartControlStateWrapper.setState(oState);
162
+ }
149
163
  }
150
164
 
151
165
  function fnControlInitialized() {
152
- bSmartControlInitialized = true;
153
-
154
166
  // deal with VM
155
- // 3 possibilties with respect to VM
167
+ // 3 possibilities with respect to VM
156
168
  // a) no VM (relevant for this control) at all
157
169
  // b) control managed as part of page wide variant management
158
170
  // c) control creates own VM
@@ -176,39 +188,35 @@ sap.ui.define([
176
188
  oVariantManagementStateWrapper = oFactory.getControlStateWrapper(oVariantManagementControl, {
177
189
  managedControlWrappers: [ oSmartControlStateWrapper ]
178
190
  });
179
- oControlAssignedResolve();
191
+ fnResolveReady();
180
192
  } else {
181
- // Resolve the ControlAssignedPromise only once the VariantManagement is
182
- // also initialized
193
+ // Wait for VariantManagement to be initialized
183
194
  oSmartControl.attachAfterVariantInitialise(fnControlInitialized);
184
195
  }
185
-
186
- return;
196
+ } else {
197
+ // No variant management or page-level variant management - ready immediately
198
+ fnResolveReady();
187
199
  }
188
- // There is no VariantManagement configured for this SmartChart/SmartTable
189
- oControlAssignedResolve(oSmartControl);
190
200
  }
191
201
 
192
202
  function fnAttachStateChanged(fnHandler) {
193
- oControlAssignedPromise.then(function () {
194
- if (bVariantManagementActive) {
195
- oVariantManagementStateWrapper.attachStateChanged(fnHandler);
196
- return;
197
- }
198
-
203
+ if (bVariantManagementActive) {
204
+ oVariantManagementStateWrapper.attachStateChanged(fnHandler);
205
+ } else {
199
206
  oSmartControlStateWrapper.attachStateChanged(fnHandler);
200
-
201
- });
207
+ }
202
208
  }
203
209
 
204
210
  return {
205
211
  getState: fnGetState,
206
212
  setState: fnSetState,
207
- setControl: fnSetControl,
208
213
  attachStateChanged: fnAttachStateChanged,
209
- bVMConnection: oSmartControl && oSmartControl.getSmartVariant && !!oSmartControl.getSmartVariant()
214
+ bVMConnection: oSmartControl && oSmartControl.getSmartVariant && !!oSmartControl.getSmartVariant(),
215
+ oVariantManagementInitializedPromise: oVariantManagementInitializedPromise,
216
+ onAfterVariantInitialise: oVariantManagementInitializedResolve,
217
+ oReadyPromise: oReadyPromise
210
218
  };
211
219
  }
212
220
 
213
221
  return SmartTableChartCommon;
214
- });
222
+ });
@@ -2,10 +2,18 @@ sap.ui.define([
2
2
  "sap/suite/ui/generic/template/genericUtilities/controlStateWrapperFactory/SmartTableChartCommon"
3
3
  ], function(SmartTableChartCommon) {
4
4
  "use strict";
5
-
5
+
6
+ /**
7
+ * Constructor for SmartTableWrapper
8
+ * @param {sap.ui.comp.smarttable.SmartTable} oSmartTable - The SmartTable control
9
+ * @param {object} oController - The controller instance
10
+ * @param {object} oFactory - The ControlStateWrapperFactory instance
11
+ * @returns {object} Wrapper object for SmartTable
12
+ */
6
13
  function SmartTableWrapper(oSmartTable, oController, oFactory){
14
+ // SmartTable extends SmartTableChartCommon with tableSettings support
7
15
  return new SmartTableChartCommon(oSmartTable, oController, oFactory, "initialise");
8
16
  }
9
17
 
10
18
  return SmartTableWrapper;
11
- });
19
+ });
@@ -4,18 +4,16 @@ sap.ui.define([
4
4
 
5
5
  /**
6
6
  * Constructor for SmartVariantManagementWrapper
7
- * @param {sap.ui.comp.smartvariants.SmartVariantManagement} vTarget - The SmartVariantManagement control
8
- * or the Id of control for which this wrapper is created
7
+ * @param {sap.ui.comp.smartvariants.SmartVariantManagement} oControl - The SmartVariantManagement control
9
8
  * @param {object} oController - the controller of the current component
10
9
  * @param {object} oFactory - the controlStateWrapperFactory
11
10
  * @param {object} mParams
12
11
  * @param {array} mParams.managedControlWrappers - array of controlStateWrappers for controls handled by the SVM
13
- * (currently also including SFB wrapper - to be removed)
14
- * @param {Object} mParams.dynamicPageWrapper - dynamicPageWrapper instance handled by SVM
12
+ * @param {object} mParams.smartFilterBarWrapper - explicit reference to SmartFilterBarWrapper for special handling
15
13
  * @returns {object}
16
14
  */
17
15
 
18
- function SmartVariantManagementWrapper(vTarget, oController, oFactory, mParams) {
16
+ function SmartVariantManagementWrapper(oControl, oController, oFactory, mParams) {
19
17
  // Special handling of SmartFilterBarWrapper for several reasons:
20
18
  // - Suppress selection when restoring a variant. Selection is solely triggered according to information in appState. Otherwise, erroneous selection could be triggered in
21
19
  // a few situations:
@@ -26,14 +24,10 @@ sap.ui.define([
26
24
  // - Store and restore extension state (extension implemented in SFB instead of SVM, which would be more appropriate from architectural point of view)
27
25
  // flag to control whether we are currently in the process of applying a state to suppress the event to inform about a new state´
28
26
  // only needed when setting the variant itself - for managed controls, their wrappers should avoid firing the event themselves
29
- var oSmartVariantManagement, fnResolveControlAssigned, oPreliminaryState;
30
- var oControlAssignedPromise = new Promise(function (resolve) {
31
- fnResolveControlAssigned = resolve;
32
- });
33
-
34
- if (typeof vTarget !== "string") {
35
- fnSetControl(vTarget);
36
- }
27
+ var oSmartVariantManagement = oControl;
28
+ var oPreliminaryState;
29
+ var bIsApplyingVariant = false;
30
+ var bAllControlsInitialized = false;
37
31
 
38
32
  // Handles the state of the variant management itself (i.e. which variant is selected and whether it's dirty), including the state of the managed controls.
39
33
  // Is responsible esp. to restore this state with correct dependency resp. in correct order
@@ -50,69 +44,74 @@ sap.ui.define([
50
44
  // For these controls, a real user changes are already handled by the direct connection. On the other hand, these controls also fire their change events, if their state is
51
45
  // changed from SVM (by the same connection) - setting variant dirty here would be wrong.
52
46
  mParams.managedControlWrappers.forEach(function(oWrapper){
53
- if (!oWrapper.bVMConnection){
54
- oWrapper.attachStateChanged(function(){
55
- oSmartVariantManagement.currentVariantSetModified(true);
56
- });
57
- }
47
+ (oWrapper.oVMConnectionPromise || Promise.resolve(oWrapper.bVMConnection)).then(function(bVMConnection) {
48
+ if (!bVMConnection) {
49
+ oWrapper.attachStateChanged(function(){
50
+ oSmartVariantManagement.currentVariantSetModified(true);
51
+ });
52
+ }
53
+ });
58
54
  });
59
55
 
56
+ // Get SmartFilterBarWrapper explicitly from params.
57
+ // This connection is needed because SmartFilterBar provides special callbacks to store/restore state
58
+ // for controls that don't have a direct variant management connection (bVMConnection = false), such as:
59
+ // - Extension filters (custom filters added via app or adaptation extensions)
60
+ // - Multiple views state (selected tab in multi-table/chart scenarios)
61
+ // These controls need their state saved/restored with variants via the SFB's beforeVariantFetch/afterVariantLoad events.
62
+ var oSmartFilterBarWrapper = mParams.smartFilterBarWrapper;
60
63
 
61
-
62
- function fnSetControl(oControl) {
63
- oSmartVariantManagement = oControl;
64
- fnResolveControlAssigned(oSmartVariantManagement);
65
- }
66
-
67
- var oSmartFilterBarWrapper = mParams.managedControlWrappers.find(function(oWrapper){
68
- return oWrapper.setSVMWrapperCallbacks;
69
- });
70
-
71
- // provide callbacks needed for SFB wrapper to store/restore extnesion state with variant
64
+ // Provide callbacks needed for SFB wrapper to store/restore extension state with variant
72
65
  if (oSmartFilterBarWrapper){
73
- oSmartFilterBarWrapper.setSVMWrapperCallbacks({
74
- getManagedControlStates: function(){
75
- var mManagedControlStates = Object.create(null);
76
- mParams.managedControlWrappers.forEach(function(oWrapper){
77
- if (!oWrapper.bVMConnection){
78
- mManagedControlStates[oWrapper.getLocalId()] = oWrapper.getState();
79
- }
80
- });
81
- return mManagedControlStates;
82
- },
83
- setManagedControlStates: function(oState){
84
- mParams.managedControlWrappers.forEach(function(oWrapper){
85
- if (!oWrapper.bVMConnection){
86
- oWrapper.setState(oState[oWrapper.getLocalId()]);
87
- }
88
- });
89
- },
90
- setHeaderState: function(bHeaderToBeExpanded) {
91
- mParams.dynamicPageWrapper.setHeaderState(oController, bHeaderToBeExpanded);
92
- }
66
+ // Build array with wrapper + bVMConnection info once all wrappers are ready
67
+ Promise.all(mParams.managedControlWrappers.map(function(oWrapper){
68
+ return (oWrapper.oVMConnectionPromise || Promise.resolve(oWrapper.bVMConnection)).then(function(bVMConnection){
69
+ return {
70
+ wrapper: oWrapper,
71
+ bVMConnection: bVMConnection
72
+ };
73
+ });
74
+ })).then(function(aWrapperInfo) {
75
+ oSmartFilterBarWrapper.setSVMWrapperCallbacks({
76
+ getManagedControlStates: function(){
77
+ var mManagedControlStates = Object.create(null);
78
+ aWrapperInfo.forEach(function(oInfo){
79
+ if (!oInfo.bVMConnection) {
80
+ mManagedControlStates[oInfo.wrapper.getLocalId()] = oInfo.wrapper.getState();
81
+ }
82
+ });
83
+ return mManagedControlStates;
84
+ },
85
+ setManagedControlStates: function(oState){
86
+ aWrapperInfo.forEach(function(oInfo){
87
+ if (!oInfo.bVMConnection) {
88
+ oInfo.wrapper.setState(oState[oInfo.wrapper.getLocalId()]);
89
+ }
90
+ });
91
+ }
92
+ });
93
93
  });
94
94
  }
95
95
 
96
+ // Create promise that resolves when all managed controls' variant management is ready
97
+ // This ensures getState() can query controls even if setState() is never called (e.g., app starts from scratch)
98
+ var oAllControlsInitializedPromise = Promise.all(
99
+ mParams.managedControlWrappers.map(function(oWrapper){
100
+ return oWrapper.oVariantManagementInitializedPromise || Promise.resolve();
101
+ })
102
+ );
103
+
104
+ // Set flag when all controls are initialized
105
+ oAllControlsInitializedPromise.then(function() {
106
+ bAllControlsInitialized = true;
107
+ });
108
+
96
109
  // Wrapper is intended to set a state to the ui, but not to trigger a selection (which should happen only after all (relevant) parts of ui state is set to the correct state
97
110
  // are set correct. Therefore, setting variant from here should never trigger a selection.
98
111
  function fnSetVariant(sVariantId){
99
112
  if (oSmartFilterBarWrapper){
100
113
  oSmartFilterBarWrapper.suppressSelection(true);
101
114
  }
102
- var sId = mParams.managedControlWrappers[0].getLocalId();
103
- var oControl = oController.getView().byId(sId);
104
- if (oControl && oControl.isA("sap.ui.comp.smarttable.SmartTable")) {
105
- oControl.attachAfterVariantInitialise(function() {
106
- //set currentVariantId only when sVariantId is not standard (as it might be overriding existing
107
- //different currentVariantId) or smartTable's (oControl) currentVariantId is not equal to sVariantId.
108
- if (sVariantId !== '*standard*' && sVariantId !== '') {
109
- if (oControl.getCurrentVariantId && oControl.getCurrentVariantId() !== sVariantId) {
110
- oControl.setCurrentVariantId(sVariantId);
111
- }
112
- oSmartVariantManagement.setModified(false);
113
- }
114
- });
115
- }
116
115
  oSmartVariantManagement.setCurrentVariantId(sVariantId);
117
116
  if (oSmartFilterBarWrapper){
118
117
  oSmartFilterBarWrapper.suppressSelection(false);
@@ -133,7 +132,11 @@ sap.ui.define([
133
132
  }
134
133
 
135
134
  function getState() {
136
- if (!oSmartVariantManagement) {
135
+ // Return preliminary state if managed controls not fully initialized
136
+ // Note: If early getState() calls become an issue (controls not initialized yet), we could enhance this to:
137
+ // - Store only SVM-specific data (variantId, modified) in oPreliminaryState
138
+ // - Always query managed control wrappers directly (they handle their own preliminary state via PreliminaryWrapper)
139
+ if (!bAllControlsInitialized) {
137
140
  return oPreliminaryState;
138
141
  }
139
142
 
@@ -150,22 +153,23 @@ sap.ui.define([
150
153
 
151
154
  function setState(oState) {
152
155
  oPreliminaryState = oState;
153
- oControlAssignedPromise.then(function() {
156
+
157
+ // Wait for all managed controls to be initialized before applying state
158
+ oAllControlsInitializedPromise.then(function() {
159
+ bIsApplyingVariant = true;
154
160
  if (!oPreliminaryState) {
155
161
  // if no state is provided set default variant (not modified)
156
162
  // use cases:
157
163
  // - LR: if appStateKey in the URL that cannot be read
158
164
  // - OP: if switching to different object instance (in discovery mode always, in persistency mode when page was not shown)
159
165
  fnSetVariant(oSmartVariantManagement.getDefaultVariantId());
160
- return;
161
- }
162
- if (oPreliminaryState.modified) {
166
+ } else if (oPreliminaryState.modified) {
163
167
  // Special logic according to UX: If variant was modified anyway, there's no benefit for the user to see the name (but it could be confusing), so standard variant (not default!) should be
164
168
  // set (which is achieved by empty string)
165
169
  fnSetVariant("");
170
+ oSmartVariantManagement.currentVariantSetModified(true);
166
171
  // Usually restoring the state of any of the managed controls should mark the variant as dirty, but there might be edge cases (state from an old release not containing information for any
167
172
  // managed control now relevant), so to be on the safe side, we set modified=true explicitly.
168
- oSmartVariantManagement.currentVariantSetModified(true);
169
173
  fnSetManagedControlStates(oPreliminaryState);
170
174
  } else {
171
175
  fnSetVariant(oPreliminaryState.variantId);
@@ -183,6 +187,7 @@ sap.ui.define([
183
187
  }
184
188
  }
185
189
  }
190
+ bIsApplyingVariant = false;
186
191
  });
187
192
  }
188
193
 
@@ -190,26 +195,30 @@ sap.ui.define([
190
195
  // state of variant management itself can be changed directly (user selects a different variant or stores current state as (new) variant), or indirectly (user changes some
191
196
  // data of a control managed by VM, e.g. some filter values in SFB)
192
197
 
193
- oControlAssignedPromise.then(function() {
194
- // state change when user selects a different variant
195
- oSmartVariantManagement.attachSelect(fnHandler);
198
+ // Wrap the handler to suppress events when applying a variant
199
+ var fnSuppressibleHandler = function() {
200
+ if (!bIsApplyingVariant) {
201
+ fnHandler();
202
+ }
203
+ };
196
204
 
197
- // when user saves current state as a new variant, this is also a state change (as the variant id is part of the state)
198
- // note: Even if new (SFB) variant is marked as execute on select, and currently no data is selected, no need to select data here (and thus also not to collapse header).
199
- // This is one of the possible ways to get into a state with a clean variant with execute on select, but no data loaded - see also comment to identify SFB wrapper.
200
- oSmartVariantManagement.attachAfterSave(fnHandler);
205
+ // state change when user selects a different variant
206
+ oSmartVariantManagement.attachSelect(fnSuppressibleHandler);
201
207
 
202
- // any change of a managed control is state change
203
- mParams.managedControlWrappers.forEach(function(oWrapper){
204
- oWrapper.attachStateChanged(fnHandler);
205
- });
208
+ // when user saves current state as a new variant, this is also a state change (as the variant id is part of the state)
209
+ // note: Even if new (SFB) variant is marked as execute on select, and currently no data is selected, no need to select data here (and thus also not to collapse header).
210
+ // This is one of the possible ways to get into a state with a clean variant with execute on select, but no data loaded - see also comment to identify SFB wrapper.
211
+ oSmartVariantManagement.attachAfterSave(fnSuppressibleHandler);
212
+
213
+ // any change of a managed control is state change
214
+ mParams.managedControlWrappers.forEach(function(oWrapper){
215
+ oWrapper.attachStateChanged(fnSuppressibleHandler);
206
216
  });
207
217
  }
208
218
 
209
219
  return {
210
220
  getState : getState,
211
221
  setState : setState,
212
- setControl: fnSetControl,
213
222
  attachStateChanged : attachStateChanged
214
223
  };
215
224
  }
@@ -939,7 +939,7 @@ sap.ui.define([
939
939
  * @extends sap.ui.core.UIComponent
940
940
  * @abstract
941
941
  * @author SAP SE
942
- * @version 1.120.41
942
+ * @version 1.120.43
943
943
  * @name sap.suite.ui.generic.template.lib.AppComponent
944
944
  */
945
945
  return UIComponent.extend("sap.suite.ui.generic.template.lib.AppComponent", {
@@ -994,6 +994,10 @@ sap.ui.define([
994
994
  type: "string",
995
995
  defaultValue: "Middle"
996
996
  },
997
+ applyButtonNavigatesImmediately : {
998
+ type:"boolean",
999
+ defaultValue: false
1000
+ },
997
1001
  //The column layout is used by default in the SmartForm on the object page
998
1002
  useColumnLayoutForSmartForm: {
999
1003
  type: "boolean",
@@ -166,7 +166,10 @@ sap.ui.define(["sap/ui/base/Object",
166
166
  oCurrentPaginatorInfo = oRet; // make sure that the navigation below does not create a new paginator info but reuses the existing one
167
167
  onListNavigate(oSourceItem, oState, oTargetContext, true, oViewProxy);
168
168
  };
169
- if (bIsActive && bIsEditItem){ // in this case oListBinding (and thus oContext which was derived from it) points to the active version, but we are already in the draft version
169
+ var oComponent = oController.getOwnerComponent();
170
+ var bOpenInEditMode = !!oComponent.getEditFlow && oComponent.getEditFlow() === "direct";
171
+
172
+ if (bIsActive && bIsEditItem && !bOpenInEditMode){ // in this case oListBinding (and thus oContext which was derived from it) points to the active version, but we are already in the draft version
170
173
  oServices.oApplication.registerContext(oContext, oComponentUtils.getViewLevel() + 1); // determine the sibling context
171
174
  var oSiblingPromise = oServices.oApplication.getDraftSiblingPromise(oContext); // as the "real" target of this pagination
172
175
  oSiblingPromise.then(fnPaginateImpl);
@@ -260,9 +260,9 @@ NOITEMS_SMARTTABLE_WITH_FILTER_FOR_SEGMENTEDBUTTON=EiRivej\u00E4ValSuodPerJaTaul
260
260
 
261
261
  NOITEMS_SMARTCHART=Tietoja ei l\u00F6ytynyt.
262
262
 
263
- NOITEMS_LR_SMARTCHART=EiTietValSuodPerJaKaavN\u00E4kVart
263
+ NOITEMS_LR_SMARTCHART=Ei tietoja valitulla suodatinperusteella ja kaavion\u00E4kym\u00E4ll\u00E4.
264
264
 
265
- NOITEMS_SMARTCHART_WITH_FILTER=TietEiL\u00F6ydy. YrS\u00E4\u00E4tSuodParam.
265
+ NOITEMS_SMARTCHART_WITH_FILTER=Tietoja ei l\u00F6ytynyt. Yrit\u00E4 s\u00E4\u00E4t\u00E4\u00E4 suodatusperusteita.
266
266
 
267
267
  SMARTCHART_INITIAL_NODATA=Aloita asettamalla suodattimet ja valitsemalla "Aloita".
268
268
 
@@ -47,13 +47,13 @@ ST_STREAM_TYPE_MISMATCH=Le type de fichier s\u00E9lectionn\u00E9 n'est pas pris
47
47
 
48
48
  ST_DRAFT_OWNER=par {0}
49
49
 
50
- ST_DRAFT_ANOTHER_USER=d'un autre utilisateur
50
+ ST_DRAFT_ANOTHER_USER=par un autre utilisateur
51
51
 
52
52
  DATA_PASTE_ERROR_MESSAGE=Impossible de coller. {0} \u00E9l\u00E9ments contiennent des donn\u00E9es non valides.
53
53
 
54
54
  DATA_PASTE_ERROR_CORRECTION_MESSAGE=Corrigez les valeurs indiqu\u00E9es ci-dessous dans votre fichier source.
55
55
 
56
- DATA_PASTE_ERROR_CORRECTION_NOTE=(Note \: ligne/colonne indique la position dans l'ensemble des donn\u00E9es qu vous avez copi\u00E9.)
56
+ DATA_PASTE_ERROR_CORRECTION_NOTE=(Note \: La ligne/colonne indique la position dans l'ensemble des donn\u00E9es que vous avez copi\u00E9.)
57
57
 
58
58
  DATA_PASTE_UNSUPPORTED_FORMAT_MESSAGE=Coller indisponible pour cette table.
59
59
 
@@ -264,7 +264,7 @@ NOITEMS_LR_SMARTCHART=Er zijn geen gegevens voor de geselecteerde filtercriteria
264
264
 
265
265
  NOITEMS_SMARTCHART_WITH_FILTER=Geen gegevens gevonden. Pas de filterparameters aan.
266
266
 
267
- SMARTCHART_INITIAL_NODATA=Stel relevante filters in en select. "Start" om te starten.
267
+ SMARTCHART_INITIAL_NODATA=Stel relevante filters in en selecteer "Start" om te starten.
268
268
 
269
269
  NOITEMS_LR_SMARTTABLE=Geen gegevens gevonden.
270
270