@sapui5/sap.fe.core 1.99.0 → 1.100.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 (246) hide show
  1. package/package.json +4 -2
  2. package/src/sap/fe/core/.library +1 -1
  3. package/src/sap/fe/core/AnnotationHelper.js +1 -69
  4. package/src/sap/fe/core/AnnotationHelper.ts +0 -70
  5. package/src/sap/fe/core/AppComponent.js +388 -399
  6. package/src/sap/fe/core/AppComponent.ts +403 -0
  7. package/src/sap/fe/core/AppStateHandler.js +127 -158
  8. package/src/sap/fe/core/BaseController.js +82 -58
  9. package/src/sap/fe/core/BaseController.ts +68 -0
  10. package/src/sap/fe/core/CommonUtils.js +111 -20
  11. package/src/sap/fe/core/CommonUtils.ts +131 -32
  12. package/src/sap/fe/core/ExtensionAPI.js +278 -274
  13. package/src/sap/fe/core/ExtensionAPI.ts +250 -0
  14. package/src/sap/fe/core/PageController.js +157 -29
  15. package/src/sap/fe/core/PageController.ts +60 -32
  16. package/src/sap/fe/core/RouterProxy.js +694 -756
  17. package/src/sap/fe/core/RouterProxy.ts +11 -9
  18. package/src/sap/fe/core/Synchronization.js +21 -31
  19. package/src/sap/fe/core/TemplateComponent.js +1 -1
  20. package/src/sap/fe/core/TemplateComponent.ts +10 -3
  21. package/src/sap/fe/core/TemplateModel.js +20 -38
  22. package/src/sap/fe/core/TemplateModel.ts +1 -1
  23. package/src/sap/fe/core/TransactionHelper.js +1354 -1370
  24. package/src/sap/fe/core/TransactionHelper.ts +33 -22
  25. package/src/sap/fe/core/actions/collaboration/ActivitySync.js +392 -0
  26. package/src/sap/fe/core/actions/collaboration/ActivitySync.ts +355 -0
  27. package/src/sap/fe/core/actions/collaboration/CollaborationCommon.js +136 -0
  28. package/src/sap/fe/core/actions/collaboration/CollaborationCommon.ts +119 -0
  29. package/src/sap/fe/core/actions/collaboration/Manage.js +262 -0
  30. package/src/sap/fe/core/actions/collaboration/Manage.ts +244 -0
  31. package/src/sap/fe/core/actions/collaboration/ManageDialog.fragment.xml +103 -0
  32. package/src/sap/fe/core/actions/collaboration/UserDetails.fragment.xml +13 -0
  33. package/src/sap/fe/core/actions/draft.js +30 -68
  34. package/src/sap/fe/core/actions/draft.ts +44 -71
  35. package/src/sap/fe/core/actions/messageHandling.js +55 -36
  36. package/src/sap/fe/core/actions/messageHandling.ts +66 -46
  37. package/src/sap/fe/core/actions/operations.js +34 -15
  38. package/src/sap/fe/core/actions/operations.ts +48 -18
  39. package/src/sap/fe/core/actions/sticky.js +17 -4
  40. package/src/sap/fe/core/actions/sticky.ts +21 -4
  41. package/src/sap/fe/core/controllerextensions/ControllerExtensionMetadata.js +69 -66
  42. package/src/sap/fe/core/controllerextensions/ControllerExtensionMetadata.ts +65 -0
  43. package/src/sap/fe/core/controllerextensions/EditFlow.js +1593 -1669
  44. package/src/sap/fe/core/controllerextensions/EditFlow.ts +1672 -0
  45. package/src/sap/fe/core/controllerextensions/IntentBasedNavigation.js +79 -54
  46. package/src/sap/fe/core/controllerextensions/IntentBasedNavigation.ts +61 -0
  47. package/src/sap/fe/core/controllerextensions/InternalEditFlow.js +718 -779
  48. package/src/sap/fe/core/controllerextensions/InternalEditFlow.ts +783 -0
  49. package/src/sap/fe/core/controllerextensions/InternalIntentBasedNavigation.js +796 -816
  50. package/src/sap/fe/core/controllerextensions/InternalIntentBasedNavigation.ts +803 -0
  51. package/src/sap/fe/core/controllerextensions/InternalRouting.js +1004 -1005
  52. package/src/sap/fe/core/controllerextensions/InternalRouting.ts +978 -0
  53. package/src/sap/fe/core/controllerextensions/KPIManagement.js +487 -521
  54. package/src/sap/fe/core/controllerextensions/KPIManagement.ts +2 -2
  55. package/src/sap/fe/core/controllerextensions/MassEdit.js +141 -169
  56. package/src/sap/fe/core/controllerextensions/MassEdit.ts +156 -0
  57. package/src/sap/fe/core/controllerextensions/MessageHandler.js +233 -244
  58. package/src/sap/fe/core/controllerextensions/MessageHandler.ts +225 -0
  59. package/src/sap/fe/core/controllerextensions/PageReady.js +301 -336
  60. package/src/sap/fe/core/controllerextensions/PageReady.ts +12 -10
  61. package/src/sap/fe/core/controllerextensions/Paginator.js +188 -175
  62. package/src/sap/fe/core/controllerextensions/Paginator.ts +163 -0
  63. package/src/sap/fe/core/controllerextensions/Placeholder.js +157 -149
  64. package/src/sap/fe/core/controllerextensions/Placeholder.ts +151 -0
  65. package/src/sap/fe/core/controllerextensions/Routing.js +144 -125
  66. package/src/sap/fe/core/controllerextensions/Routing.ts +132 -0
  67. package/src/sap/fe/core/controllerextensions/RoutingListener.js +7 -6
  68. package/src/sap/fe/core/controllerextensions/RoutingListener.ts +3 -0
  69. package/src/sap/fe/core/controllerextensions/Share.js +230 -268
  70. package/src/sap/fe/core/controllerextensions/Share.ts +231 -0
  71. package/src/sap/fe/core/controllerextensions/SideEffects.js +592 -633
  72. package/src/sap/fe/core/controllerextensions/SideEffects.ts +8 -7
  73. package/src/sap/fe/core/controllerextensions/ViewState.js +788 -806
  74. package/src/sap/fe/core/controllerextensions/ViewState.ts +805 -0
  75. package/src/sap/fe/core/controls/ActionParameterDialog.fragment.xml +2 -2
  76. package/src/sap/fe/core/controls/ActionPartial.fragment.xml +2 -2
  77. package/src/sap/fe/core/controls/CommandExecution.js +67 -66
  78. package/src/sap/fe/core/controls/CommandExecution.ts +72 -0
  79. package/src/sap/fe/core/controls/ConditionalWrapper.js +90 -75
  80. package/src/sap/fe/core/controls/ConditionalWrapper.ts +83 -0
  81. package/src/sap/fe/core/controls/CustomQuickViewPage.js +130 -125
  82. package/src/sap/fe/core/controls/CustomQuickViewPage.ts +126 -0
  83. package/src/sap/fe/core/controls/DataLossOrDraftDiscard/DataLossOrDraftDiscardHandler.js +103 -112
  84. package/src/sap/fe/core/controls/DataLossOrDraftDiscard/DataLossOrDraftDiscardHandler.ts +101 -0
  85. package/src/sap/fe/core/controls/FieldWrapper.js +122 -135
  86. package/src/sap/fe/core/controls/FieldWrapper.ts +115 -0
  87. package/src/sap/fe/core/controls/FilterBar.js +162 -159
  88. package/src/sap/fe/core/controls/FilterBar.ts +143 -0
  89. package/src/sap/fe/core/controls/FormElementWrapper.js +45 -39
  90. package/src/sap/fe/core/controls/FormElementWrapper.ts +40 -0
  91. package/src/sap/fe/core/controls/MultiValueParameterDelegate.js +37 -42
  92. package/src/sap/fe/core/controls/MultiValueParameterDelegate.ts +31 -0
  93. package/src/sap/fe/core/controls/filterbar/FilterContainer.js +126 -116
  94. package/src/sap/fe/core/controls/filterbar/FilterContainer.ts +98 -0
  95. package/src/sap/fe/core/controls/filterbar/VisualFilter.js +241 -255
  96. package/src/sap/fe/core/controls/filterbar/VisualFilter.ts +245 -0
  97. package/src/sap/fe/core/controls/filterbar/VisualFilterContainer.js +150 -141
  98. package/src/sap/fe/core/controls/filterbar/VisualFilterContainer.ts +125 -0
  99. package/src/sap/fe/core/controls/filterbar/utils/VisualFilterUtils.js +335 -322
  100. package/src/sap/fe/core/controls/filterbar/utils/VisualFilterUtils.ts +337 -0
  101. package/src/sap/fe/core/controls/massEdit/MassEditHandlers.js +74 -74
  102. package/src/sap/fe/core/controls/massEdit/MassEditHandlers.ts +70 -0
  103. package/src/sap/fe/core/converters/ConverterContext.js +348 -379
  104. package/src/sap/fe/core/converters/ConverterContext.ts +19 -16
  105. package/src/sap/fe/core/converters/ManifestSettings.js +12 -1
  106. package/src/sap/fe/core/converters/ManifestSettings.ts +12 -1
  107. package/src/sap/fe/core/converters/ManifestWrapper.js +354 -378
  108. package/src/sap/fe/core/converters/ManifestWrapper.ts +10 -0
  109. package/src/sap/fe/core/converters/MetaModelConverter.js +6 -4
  110. package/src/sap/fe/core/converters/MetaModelConverter.ts +5 -2
  111. package/src/sap/fe/core/converters/TemplateConverter.js +1 -1
  112. package/src/sap/fe/core/converters/TemplateConverter.ts +2 -1
  113. package/src/sap/fe/core/converters/annotations/DataField.js +26 -12
  114. package/src/sap/fe/core/converters/annotations/DataField.ts +37 -13
  115. package/src/sap/fe/core/converters/controls/Common/Form.js +2 -2
  116. package/src/sap/fe/core/converters/controls/Common/Form.ts +4 -2
  117. package/src/sap/fe/core/converters/controls/Common/KPI.js +1 -1
  118. package/src/sap/fe/core/converters/controls/Common/KPI.ts +3 -2
  119. package/src/sap/fe/core/converters/controls/Common/Table.js +130 -23
  120. package/src/sap/fe/core/converters/controls/Common/Table.ts +134 -29
  121. package/src/sap/fe/core/converters/controls/Common/table/StandardActions.js +118 -53
  122. package/src/sap/fe/core/converters/controls/Common/table/StandardActions.ts +156 -93
  123. package/src/sap/fe/core/converters/controls/ListReport/FilterBar.js +161 -207
  124. package/src/sap/fe/core/converters/controls/ListReport/FilterBar.ts +148 -206
  125. package/src/sap/fe/core/converters/helpers/Aggregation.js +115 -133
  126. package/src/sap/fe/core/converters/helpers/BindingHelper.js +20 -6
  127. package/src/sap/fe/core/converters/helpers/BindingHelper.ts +16 -4
  128. package/src/sap/fe/core/converters/helpers/ConfigurableObject.js +12 -1
  129. package/src/sap/fe/core/converters/helpers/ConfigurableObject.ts +11 -0
  130. package/src/sap/fe/core/converters/helpers/Key.js +42 -57
  131. package/src/sap/fe/core/converters/helpers/Key.ts +1 -1
  132. package/src/sap/fe/core/converters/objectPage/HeaderAndFooterAction.js +25 -4
  133. package/src/sap/fe/core/converters/objectPage/HeaderAndFooterAction.ts +20 -3
  134. package/src/sap/fe/core/converters/templates/ListReportConverter.js +10 -4
  135. package/src/sap/fe/core/converters/templates/ListReportConverter.ts +15 -4
  136. package/src/sap/fe/core/converters/templates/ObjectPageConverter.js +7 -5
  137. package/src/sap/fe/core/converters/templates/ObjectPageConverter.ts +5 -1
  138. package/src/sap/fe/core/designtime/AppComponent.designtime.js +92 -98
  139. package/src/sap/fe/core/designtime/AppComponent.designtime.ts +91 -0
  140. package/src/sap/fe/core/formatters/CollaborationFormatter.js +104 -0
  141. package/src/sap/fe/core/formatters/CollaborationFormatter.ts +60 -0
  142. package/src/sap/fe/core/formatters/TableFormatter.js +53 -2
  143. package/src/sap/fe/core/formatters/TableFormatter.ts +51 -0
  144. package/src/sap/fe/core/fpm/Component.js +50 -54
  145. package/src/sap/fe/core/fpm/Component.ts +48 -0
  146. package/src/sap/fe/core/helpers/AppStartupHelper.js +323 -309
  147. package/src/sap/fe/core/helpers/AppStartupHelper.ts +363 -337
  148. package/src/sap/fe/core/helpers/BindingExpression.js +7 -7
  149. package/src/sap/fe/core/helpers/BindingExpression.ts +7 -7
  150. package/src/sap/fe/core/helpers/ClassSupport.js +186 -62
  151. package/src/sap/fe/core/helpers/ClassSupport.ts +168 -52
  152. package/src/sap/fe/core/helpers/DynamicAnnotationPathHelper.js +5 -4
  153. package/src/sap/fe/core/helpers/DynamicAnnotationPathHelper.ts +1 -5
  154. package/src/sap/fe/core/helpers/FPMHelper.js +1 -1
  155. package/src/sap/fe/core/helpers/FPMHelper.ts +1 -1
  156. package/src/sap/fe/core/helpers/MassEditHelper.js +601 -684
  157. package/src/sap/fe/core/helpers/MassEditHelper.ts +699 -0
  158. package/src/sap/fe/core/helpers/ModelHelper.js +25 -1
  159. package/src/sap/fe/core/helpers/ModelHelper.ts +23 -0
  160. package/src/sap/fe/core/helpers/SemanticDateOperators.js +5 -1
  161. package/src/sap/fe/core/helpers/SemanticDateOperators.ts +4 -0
  162. package/src/sap/fe/core/library.js +426 -451
  163. package/src/sap/fe/core/library.support.js +22 -33
  164. package/src/sap/fe/core/library.support.ts +23 -0
  165. package/src/sap/fe/core/library.ts +420 -0
  166. package/src/sap/fe/core/manifestMerger/ChangePageConfiguration.js +5 -3
  167. package/src/sap/fe/core/manifestMerger/ChangePageConfiguration.ts +4 -1
  168. package/src/sap/fe/core/messagebundle.properties +22 -5
  169. package/src/sap/fe/core/messagebundle_ar.properties +27 -7
  170. package/src/sap/fe/core/messagebundle_bg.properties +27 -7
  171. package/src/sap/fe/core/messagebundle_ca.properties +27 -7
  172. package/src/sap/fe/core/messagebundle_cs.properties +27 -7
  173. package/src/sap/fe/core/messagebundle_cy.properties +27 -7
  174. package/src/sap/fe/core/messagebundle_da.properties +27 -7
  175. package/src/sap/fe/core/messagebundle_de.properties +27 -7
  176. package/src/sap/fe/core/messagebundle_el.properties +27 -7
  177. package/src/sap/fe/core/messagebundle_en.properties +27 -7
  178. package/src/sap/fe/core/messagebundle_en_GB.properties +27 -7
  179. package/src/sap/fe/core/messagebundle_en_US_sappsd.properties +27 -7
  180. package/src/sap/fe/core/messagebundle_en_US_saprigi.properties +27 -7
  181. package/src/sap/fe/core/messagebundle_en_US_saptrc.properties +27 -7
  182. package/src/sap/fe/core/messagebundle_es.properties +27 -7
  183. package/src/sap/fe/core/messagebundle_es_MX.properties +27 -7
  184. package/src/sap/fe/core/messagebundle_et.properties +27 -7
  185. package/src/sap/fe/core/messagebundle_fi.properties +28 -8
  186. package/src/sap/fe/core/messagebundle_fr.properties +28 -8
  187. package/src/sap/fe/core/messagebundle_fr_CA.properties +29 -9
  188. package/src/sap/fe/core/messagebundle_hi.properties +27 -7
  189. package/src/sap/fe/core/messagebundle_hr.properties +27 -7
  190. package/src/sap/fe/core/messagebundle_hu.properties +27 -7
  191. package/src/sap/fe/core/messagebundle_id.properties +27 -7
  192. package/src/sap/fe/core/messagebundle_it.properties +27 -7
  193. package/src/sap/fe/core/messagebundle_iw.properties +27 -7
  194. package/src/sap/fe/core/messagebundle_ja.properties +26 -6
  195. package/src/sap/fe/core/messagebundle_kk.properties +27 -7
  196. package/src/sap/fe/core/messagebundle_ko.properties +27 -7
  197. package/src/sap/fe/core/messagebundle_lt.properties +27 -7
  198. package/src/sap/fe/core/messagebundle_lv.properties +28 -8
  199. package/src/sap/fe/core/messagebundle_ms.properties +27 -7
  200. package/src/sap/fe/core/messagebundle_nl.properties +27 -7
  201. package/src/sap/fe/core/messagebundle_no.properties +27 -7
  202. package/src/sap/fe/core/messagebundle_pl.properties +27 -7
  203. package/src/sap/fe/core/messagebundle_pt.properties +28 -8
  204. package/src/sap/fe/core/messagebundle_pt_PT.properties +27 -7
  205. package/src/sap/fe/core/messagebundle_ro.properties +27 -7
  206. package/src/sap/fe/core/messagebundle_ru.properties +27 -7
  207. package/src/sap/fe/core/messagebundle_sh.properties +27 -7
  208. package/src/sap/fe/core/messagebundle_sk.properties +27 -7
  209. package/src/sap/fe/core/messagebundle_sl.properties +27 -7
  210. package/src/sap/fe/core/messagebundle_sv.properties +27 -7
  211. package/src/sap/fe/core/messagebundle_th.properties +26 -6
  212. package/src/sap/fe/core/messagebundle_tr.properties +30 -10
  213. package/src/sap/fe/core/messagebundle_uk.properties +27 -7
  214. package/src/sap/fe/core/messagebundle_vi.properties +27 -7
  215. package/src/sap/fe/core/messagebundle_zh_CN.properties +27 -7
  216. package/src/sap/fe/core/messagebundle_zh_TW.properties +27 -7
  217. package/src/sap/fe/core/services/AsyncComponentServiceFactory.js +45 -71
  218. package/src/sap/fe/core/services/CacheHandlerServiceFactory.js +154 -192
  219. package/src/sap/fe/core/services/CacheHandlerServiceFactory.ts +4 -4
  220. package/src/sap/fe/core/services/EnvironmentServiceFactory.js +66 -92
  221. package/src/sap/fe/core/services/EnvironmentServiceFactory.ts +1 -1
  222. package/src/sap/fe/core/services/NavigationServiceFactory.js +284 -339
  223. package/src/sap/fe/core/services/NavigationServiceFactory.ts +10 -13
  224. package/src/sap/fe/core/services/ResourceModelServiceFactory.js +67 -102
  225. package/src/sap/fe/core/services/ResourceModelServiceFactory.ts +5 -2
  226. package/src/sap/fe/core/services/RoutingServiceFactory.js +754 -814
  227. package/src/sap/fe/core/services/RoutingServiceFactory.ts +13 -13
  228. package/src/sap/fe/core/services/ShellServicesFactory.js +649 -736
  229. package/src/sap/fe/core/services/ShellServicesFactory.ts +7 -4
  230. package/src/sap/fe/core/services/SideEffectsServiceFactory.js +567 -592
  231. package/src/sap/fe/core/services/SideEffectsServiceFactory.ts +22 -3
  232. package/src/sap/fe/core/services/TemplatedViewServiceFactory.js +354 -386
  233. package/src/sap/fe/core/services/TemplatedViewServiceFactory.ts +21 -14
  234. package/src/sap/fe/core/services/view/TemplatingErrorPage.controller.js +1 -1
  235. package/src/sap/fe/core/services/view/TemplatingErrorPage.controller.ts +1 -1
  236. package/src/sap/fe/core/support/CommonHelper.js +1 -1
  237. package/src/sap/fe/core/support/CommonHelper.ts +1 -1
  238. package/src/sap/fe/core/support/Diagnostics.js +36 -48
  239. package/src/sap/fe/core/templating/DataModelPathHelper.js +93 -85
  240. package/src/sap/fe/core/templating/DataModelPathHelper.ts +104 -95
  241. package/src/sap/fe/core/templating/FilterHelper.js +25 -32
  242. package/src/sap/fe/core/templating/FilterHelper.ts +36 -35
  243. package/src/sap/fe/core/templating/PropertyHelper.js +2 -2
  244. package/src/sap/fe/core/templating/PropertyHelper.ts +1 -1
  245. package/src/sap/fe/core/templating/UIFormatters.js +32 -26
  246. package/src/sap/fe/core/templating/UIFormatters.ts +37 -24
@@ -1,809 +1,791 @@
1
1
  /*!
2
2
  * SAP UI development toolkit for HTML5 (SAPUI5)
3
- (c) Copyright 2009-2021 SAP SE. All rights reserved
4
-
3
+ * (c) Copyright 2009-2021 SAP SE. All rights reserved
5
4
  */
6
- sap.ui.define(
7
- [
8
- "sap/ui/core/mvc/ControllerExtension",
9
- "sap/ui/core/mvc/OverrideExecution",
10
- "sap/base/Log",
11
- "sap/base/util/merge",
12
- "sap/ui/fl/apply/api/ControlVariantApplyAPI",
13
- "sap/ui/mdc/p13n/StateUtil",
14
- "sap/fe/navigation/library",
15
- "sap/fe/core/CommonUtils",
16
- "sap/fe/core/helpers/KeepAliveHelper",
17
- "sap/fe/core/helpers/ModelHelper"
18
- ],
19
- function(
20
- ControllerExtension,
21
- OverrideExecution,
22
- Log,
23
- mergeObjects,
24
- ControlVariantApplyAPI,
25
- StateUtil,
26
- NavLibrary,
27
- CommonUtils,
28
- KeepAliveHelper,
29
- ModelHelper
30
- ) {
31
- "use strict";
32
-
33
- // additionalStates are stored next to control IDs, so name clash avoidance needed. Fortunately IDs have restrictions:
34
- // "Allowed is a sequence of characters (capital/lowercase), digits, underscores, dashes, points and/or colons."
35
- // Therefore adding a symbol like # or @
36
- var ADDITIONAL_STATES_KEY = "#additionalStates",
37
- NavType = NavLibrary.NavType;
38
-
39
- ///////////////////////////////////////////////////////////////////
40
- // methods to retrieve & apply states for the different controls //
41
- ///////////////////////////////////////////////////////////////////
42
-
43
- var _mControlStateHandlerMap = {
44
- "sap.ui.fl.variants.VariantManagement": {
45
- retrieve: function(oVM) {
46
- return {
47
- "variantId": oVM.getCurrentVariantKey()
48
- };
49
- },
50
- apply: function(oVM, oControlState) {
51
- if (oControlState && oControlState.variantId !== undefined && oControlState.variantId !== oVM.getCurrentVariantKey()) {
52
- var sVariantReference = this._checkIfVariantIdIsAvailable(oVM, oControlState.variantId)
53
- ? oControlState.variantId
54
- : oVM.getStandardVariantKey();
55
- return ControlVariantApplyAPI.activateVariant({
56
- element: oVM,
57
- variantReference: sVariantReference
58
- });
59
- }
60
- }
61
- },
62
- "sap.m.IconTabBar": {
63
- retrieve: function(oTabBar) {
64
- return {
65
- selectedKey: oTabBar.getSelectedKey()
66
- };
67
- },
68
- apply: function(oTabBar, oControlState) {
69
- if (oControlState && oControlState.selectedKey) {
70
- var oSelectedItem = oTabBar.getItems().find(function(oItem) {
71
- return oItem.getKey() === oControlState.selectedKey;
72
- });
73
- if (oSelectedItem) {
74
- oTabBar.setSelectedItem(oSelectedItem);
75
- }
76
- }
77
- }
78
- },
79
- "sap.ui.mdc.FilterBar": {
80
- retrieve: function(oFilterBar) {
81
- return StateUtil.retrieveExternalState(oFilterBar).then(function(mFilterBarState) {
82
- // remove sensitive or view state irrelevant fields
83
- var aPropertiesInfo = oFilterBar.getPropertyInfoSet(),
84
- mFilter = mFilterBarState.filter || {};
85
- aPropertiesInfo
86
- .filter(function(oPropertyInfo) {
87
- return (
88
- mFilter[oPropertyInfo.path] &&
89
- (oPropertyInfo.removeFromAppState || mFilter[oPropertyInfo.path].length === 0)
90
- );
91
- })
92
- .forEach(function(oPropertyInfo) {
93
- delete mFilter[oPropertyInfo.path];
94
- });
95
- return mFilterBarState;
96
- });
97
- },
98
- apply: function(oFilterBar, oControlState) {
99
- if (oControlState) {
100
- return StateUtil.applyExternalState(oFilterBar, oControlState);
101
- }
102
- }
103
- },
104
- "sap.ui.mdc.Table": {
105
- retrieve: function(oTable) {
106
- return StateUtil.retrieveExternalState(oTable);
107
- },
108
- apply: function(oTable, oControlState) {
109
- if (oControlState) {
110
- return StateUtil.applyExternalState(oTable, oControlState);
111
- }
112
- },
113
- refreshBinding: function(oTable) {
114
- var oTableBinding = oTable.getRowBinding();
115
- if (oTableBinding) {
116
- var oRootBinding = oTableBinding.getRootBinding();
117
- if (oRootBinding === oTableBinding) {
118
- // absolute binding
119
- oTableBinding.refresh();
120
- } else {
121
- // relative binding
122
- var oHeaderContext = oTableBinding.getHeaderContext();
123
- var sGroupId = oTableBinding.getGroupId();
124
-
125
- if (oHeaderContext) {
126
- oHeaderContext.requestSideEffects([{ $NavigationPropertyPath: "" }], sGroupId);
127
- }
128
- }
129
- } else {
130
- Log.info("Table: " + oTable.getId() + " was not refreshed. No binding found!");
131
- }
132
- }
133
- },
134
- "sap.uxap.ObjectPageLayout": {
135
- retrieve: function(oOPLayout) {
136
- return {
137
- selectedSection: oOPLayout.getSelectedSection()
138
- };
139
- },
140
- apply: function(oOPLayout, oControlState) {
141
- oControlState && oOPLayout.setSelectedSection(oControlState.selectedSection);
142
- },
143
- refreshBinding: function(oOPLayout) {
144
- var oBindingContext = oOPLayout.getBindingContext();
145
- var oBinding = oBindingContext && oBindingContext.getBinding();
146
- if (oBinding) {
147
- var sMetaPath = ModelHelper.getMetaPathForContext(oBindingContext);
148
- var sStrategy = KeepAliveHelper.getControlRefreshStrategyForContextPath(oOPLayout, sMetaPath);
149
- if (sStrategy === "self") {
150
- // Refresh main context and 1-1 navigation properties or OP
151
- var oModel = oBindingContext.getModel(),
152
- oMetaModel = oModel.getMetaModel(),
153
- oNavigationProperties =
154
- CommonUtils.getContextPathProperties(oMetaModel, sMetaPath, {
155
- $kind: "NavigationProperty"
156
- }) || {},
157
- aNavPropertiesToRequest = Object.keys(oNavigationProperties).reduce(function(aPrev, sNavProp) {
158
- if (oNavigationProperties[sNavProp].$isCollection !== true) {
159
- aPrev.push({ $NavigationPropertyPath: sNavProp });
160
- }
161
- return aPrev;
162
- }, []),
163
- aProperties = [{ $PropertyPath: "*" }],
164
- sGroupId = oBinding.getGroupId();
165
-
166
- oBindingContext.requestSideEffects(aProperties.concat(aNavPropertiesToRequest), sGroupId);
167
- } else if (sStrategy === "includingDependents") {
168
- // Complete refresh
169
- oBinding.refresh();
170
- }
171
- } else {
172
- Log.info("ObjectPage: " + oOPLayout.getId() + " was not refreshed. No binding found!");
173
- }
174
- }
175
- },
176
- "sap.fe.macros.table.QuickFilterContainer": {
177
- retrieve: function(oQuickFilter) {
178
- return {
179
- selectedKey: oQuickFilter.getSelectorKey()
180
- };
181
- },
182
- apply: function(oQuickFilter, oControlState) {
183
- oControlState && oQuickFilter.setSelectorKey(oControlState.selectedKey);
184
- }
185
- },
186
- "sap.m.SegmentedButton": {
187
- retrieve: function(oSegmentedButton) {
188
- return {
189
- selectedKey: oSegmentedButton.getSelectedKey()
190
- };
191
- },
192
- apply: function(oSegmentedButton, oControlState) {
193
- oControlState && oSegmentedButton.setSelectedKey(oControlState.selectedKey);
194
- }
195
- },
196
- "sap.m.Select": {
197
- retrieve: function(oSelect) {
198
- return {
199
- selectedKey: oSelect.getSelectedKey()
200
- };
201
- },
202
- apply: function(oSelect, oControlState) {
203
- oControlState && oSelect.setSelectedKey(oControlState.selectedKey);
204
- }
205
- },
206
- "sap.f.DynamicPage": {
207
- retrieve: function(oDynamicPage) {
208
- return {
209
- headerExpanded: oDynamicPage.getHeaderExpanded()
210
- };
211
- },
212
- apply: function(oDynamicPage, oControlState) {
213
- oControlState && oDynamicPage.setHeaderExpanded(oControlState.headerExpanded);
214
- }
215
- },
216
- "sap.ui.core.mvc.View": {
217
- retrieve: function(oView) {
218
- var oController = oView.getController();
219
- if (oController && oController.viewState) {
220
- return oController.viewState.retrieveViewState(oController.viewState);
221
- }
222
- return {};
223
- },
224
- apply: function(oView, oControlState, oNavParameters) {
225
- var oController = oView.getController();
226
- if (oController && oController.viewState) {
227
- return oController.viewState.applyViewState(oControlState, oNavParameters);
228
- }
229
- },
230
- refreshBinding: function(oView) {
231
- var oController = oView.getController();
232
- if (oController && oController.viewState) {
233
- return oController.viewState.refreshViewBindings();
234
- }
235
- }
236
- },
237
- "sap.ui.core.ComponentContainer": {
238
- retrieve: function(oComponentContainer) {
239
- var oComponent = oComponentContainer.getComponentInstance();
240
- if (oComponent) {
241
- return this.retrieveControlState(oComponent.getRootControl());
242
- }
243
- return {};
244
- },
245
- apply: function(oComponentContainer, oControlState, oNavParameters) {
246
- var oComponent = oComponentContainer.getComponentInstance();
247
- if (oComponent) {
248
- return this.applyControlState(oComponent.getRootControl(), oControlState, oNavParameters);
249
- }
250
- }
251
- }
252
- };
253
-
254
- /**
255
- * @class A controller extension offering hooks for state handling
256
- *
257
- * If you need to maintain a specific state for your application, you can use the controller extension.
258
- *
259
- * @name sap.fe.core.controllerextensions.ViewState
260
- * @hideconstructor
261
- * @public
262
- * @since 1.85.0
263
- */
264
- var ViewState = ControllerExtension.extend("sap.fe.core.controllerextensions.ViewState", {
265
- metadata: {
266
- methods: {
267
- refreshViewBindings: { "public": true, "final": true },
268
- adaptBindingRefreshControls: {
269
- "public": true,
270
- "final": false,
271
- overrideExecution: OverrideExecution.After
272
- },
273
- getControlRefreshBindingHandler: {
274
- "public": false,
275
- "final": true
276
- },
277
- refreshControlBinding: {
278
- "public": false,
279
- "final": true
280
- },
281
- adaptBindingRefreshHandler: {
282
- "public": true,
283
- "final": false,
284
- overrideExecution: OverrideExecution.After
285
- },
286
- collectResults: { "public": false, "final": true },
287
- adaptControlStateHandler: {
288
- "public": true,
289
- "final": false,
290
- overrideExecution: OverrideExecution.After
291
- },
292
- getControlStateHandler: { "public": false, "final": true },
293
- adaptStateControls: {
294
- "public": true,
295
- "final": false,
296
- overrideExecution: OverrideExecution.After
297
- },
298
- retrieveAdditionalStates: {
299
- "public": true,
300
- "final": false,
301
- overrideExecution: OverrideExecution.After
302
- },
303
- retrieveViewState: { "public": true, "final": true },
304
- retrieveControlState: { "public": false, "final": true },
305
- applyInitialStateOnly: {
306
- "public": true,
307
- "final": false,
308
- overrideExecution: OverrideExecution.Instead
309
- },
310
- applyViewState: { "public": true, "final": true },
311
- applyControlState: { "public": false, "final": true },
312
- applyAdditionalStates: {
313
- "public": true,
314
- "final": false,
315
- overrideExecution: OverrideExecution.After
316
- },
317
- applyNavigationParameters: { "public": true, "final": false, overrideExecution: OverrideExecution.After },
318
- onBeforeStateApplied: { "public": true, "final": false, overrideExecution: OverrideExecution.After },
319
- onAfterStateApplied: { "public": true, "final": false, overrideExecution: OverrideExecution.After },
320
- onSuspend: { "public": true, "final": false, overrideExecution: OverrideExecution.After },
321
- onRestore: { "public": true, "final": false, overrideExecution: OverrideExecution.After }
322
- }
323
- },
324
-
325
- /**
326
- * Constructor.
327
- */
328
- constructor: function() {
329
- ControllerExtension.apply(this);
330
- var that = this;
331
- that._iRetrievingStateCounter = 0;
332
- this._pInitialStateApplied = new Promise(function(resolve) {
333
- that._pInitialStateAppliedResolve = resolve;
334
- });
335
- },
336
-
337
- /**
338
- * @private
339
- * @name sap.fe.core.controllerextensions.ViewState.getMetadata
340
- * @function
341
- */
342
- /**
343
- * @private
344
- * @name sap.fe.core.controllerextensions.ViewState.extend
345
- * @function
346
- */
347
-
348
- refreshViewBindings: function() {
349
- var that = this;
350
- return that.collectResults(that.base.viewState.adaptBindingRefreshControls).then(function(aControls) {
351
- var oPromiseChain = Promise.resolve();
352
- aControls
353
- .filter(function(oControl) {
354
- return oControl && oControl.isA && oControl.isA("sap.ui.base.ManagedObject");
355
- })
356
- .forEach(function(oControl) {
357
- oPromiseChain = oPromiseChain.then(that.refreshControlBinding.bind(that, oControl));
358
- });
359
- return oPromiseChain;
360
- });
361
- },
362
- /**
363
- * This function should add all controls relevant for refreshing to the provided control array.
364
- *
365
- * This function is meant to be individually overridden by consuming controllers, but not to be called directly.
366
- * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.
367
- * @param {Array<sap.ui.base.ManagedObject>} aCollectedControls The collected controls
368
- * @alias sap.fe.core.controllerextensions.ViewState#adaptBindingRefreshControls
369
- * @protected
370
- */
371
- adaptBindingRefreshControls: function(aCollectedControls) {},
372
-
373
- refreshControlBinding: function(oControl) {
374
- var oControlRefreshBindingHandler = this.getControlRefreshBindingHandler(oControl),
375
- oPromiseChain = Promise.resolve(),
376
- that = this;
377
- if (typeof oControlRefreshBindingHandler.refreshBinding !== "function") {
378
- Log.info("refreshBinding handler for control: " + oControl.getMetadata().getName() + " is not provided");
379
- } else {
380
- oPromiseChain = oPromiseChain.then(oControlRefreshBindingHandler.refreshBinding.bind(that, oControl));
381
- }
382
- return oPromiseChain;
383
- },
384
-
385
- /**
386
- * Returns a map of <code>refreshBinding</code> function for a certain control.
387
- *
388
- * @param {sap.ui.base.ManagedObject} oControl The control to get state handler for
389
- * @returns {object} A plain object with one function: <code>refreshBinding</code>
390
- */
391
-
392
- getControlRefreshBindingHandler: function(oControl) {
393
- var oRefreshBindingHandler = {};
394
- if (oControl) {
395
- for (var sType in _mControlStateHandlerMap) {
396
- if (oControl.isA(sType)) {
397
- // pass only the refreshBinding handler in an object so that :
398
- // 1. Application has access only to refreshBinding and not apply and reterive at this stage
399
- // 2. Application modifications to the object will be reflected here (as we pass by reference)
400
- oRefreshBindingHandler["refreshBinding"] = _mControlStateHandlerMap[sType].refreshBinding || {};
401
- break;
402
- }
403
- }
404
- }
405
- this.base.viewState.adaptBindingRefreshHandler(oControl, oRefreshBindingHandler);
406
- return oRefreshBindingHandler;
407
- },
408
- /**
409
- * Customize the <code>refreshBinding</code> function for a certain control.
410
- *
411
- * This function is meant to be individually overridden by consuming controllers, but not to be called directly.
412
- * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.
413
- *
414
- * @param {sap.ui.base.ManagedObject} oControl The control for which the refresh handler is adapted.
415
- * @param {Array<object>} oControlHandler A plain object which can have one function: <code>refreshBinding</code>
416
- *
417
- * @alias sap.fe.core.controllerextensions.ViewState#adaptBindingRefreshHandler
418
- * @protected
419
- */
420
- adaptBindingRefreshHandler: function(oControl, oControlHandler) {},
421
-
422
- /**
423
- * Called when the application is suspended due to keep-alive mode.
424
- *
425
- * @alias sap.fe.core.controllerextensions.ViewState#onSuspend
426
- * @public
427
- */
428
- onSuspend: function() {},
429
-
430
- /**
431
- * Called when the application is restored due to keep-alive mode.
432
- *
433
- * @alias sap.fe.core.controllerextensions.ViewState#onRestore
434
- * @public
435
- */
436
- onRestore: function() {},
437
-
438
- /**
439
- * Destructor method for objects.
440
- */
441
- destroy: function() {
442
- delete this._pInitialStateApplied;
443
- delete this._pInitialStateAppliedResolve;
444
- delete this._iRetrievingStateCounter;
445
- ControllerExtension.prototype.destroy.apply(this);
446
- },
447
-
448
- /**
449
- * Helper function to enable multi override. It is adding an additional parameter (array) to the provided
450
- * function (and its parameters), that will be evaluated via <code>Promise.all</code>.
451
- *
452
- * @param {Function} fnCall The function to be called
453
- * @returns {Promise} A promise to be resolved with the result of all overrides
454
- */
455
- collectResults: function(fnCall) {
456
- var aResults = [],
457
- aArguments = Array.prototype.slice.call(arguments, 1);
458
- aArguments.push(aResults);
459
- fnCall.apply(this, aArguments);
460
- return Promise.all(aResults);
461
- },
462
-
463
- /**
464
- * Customize the <code>retrieve</code> and <code>apply</code> functions for a certain control.
465
- *
466
- * This function is meant to be individually overridden by consuming controllers, but not to be called directly.
467
- * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.
468
- *
469
- * @param {sap.ui.base.ManagedObject} oControl The control to get state handler for
470
- * @param {Array<object>} aControlHandler A list of plain objects with two functions: <code>retrieve</code> and <code>apply</code>
471
- *
472
- * @alias sap.fe.core.controllerextensions.ViewState#adaptControlStateHandler
473
- * @protected
474
- */
475
- adaptControlStateHandler: function(oControl, aControlHandler) {
476
- // to be overridden if needed
477
- },
478
-
479
- /**
480
- * Returns a map of <code>retrieve</code> and <code>apply</code> functions for a certain control.
481
- *
482
- * @param {sap.ui.base.ManagedObject} oControl The control to get state handler for
483
- * @returns {object} A plain object with two functions: <code>retrieve</code> and <code>apply</code>
484
- */
485
- getControlStateHandler: function(oControl) {
486
- var aInternalControlStateHandler = [],
487
- aCustomControlStateHandler = [];
488
- if (oControl) {
489
- for (var sType in _mControlStateHandlerMap) {
490
- if (oControl.isA(sType)) {
491
- // avoid direct manipulation of internal _mControlStateHandlerMap
492
- aInternalControlStateHandler.push(Object.assign({}, _mControlStateHandlerMap[sType]));
493
- break;
494
- }
495
- }
496
- }
497
- this.base.viewState.adaptControlStateHandler(oControl, aCustomControlStateHandler);
498
- return aInternalControlStateHandler.concat(aCustomControlStateHandler);
499
- },
500
-
501
- /**
502
- * This function should add all controls for given view that should be considered for the state handling to the provided control array.
503
- *
504
- * This function is meant to be individually overridden by consuming controllers, but not to be called directly.
505
- * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.
506
- * @param {Array<sap.ui.base.ManagedObject>} aCollectedControls The collected controls
507
- * @alias sap.fe.core.controllerextensions.ViewState#adaptStateControls
508
- * @protected
509
- */
510
- adaptStateControls: function(aCollectedControls) {
511
- // to be overridden if needed
512
- },
513
-
514
- /**
515
- * Returns the key to be used for given control.
516
- *
517
- * @param {sap.ui.base.ManagedObject} oControl The control to get state key for
518
- * @returns {string} The key to be used for storing the controls state
519
- */
520
- getStateKey: function(oControl) {
521
- return this.getView().getLocalId(oControl.getId()) || oControl.getId();
522
- },
523
-
524
- /**
525
- * Retrieve the view state of this extensions view.
526
- * When this function is called more than once before finishing, all but the final response will resolve to <code>undefined</code>.
527
- *
528
- * @returns {Promise} A promise resolving the view state
529
- *
530
- * @alias sap.fe.core.controllerextensions.ViewState#retrieveViewState
531
- * @public
532
- */
533
- retrieveViewState: function() {
534
- var that = this;
535
- ++that._iRetrievingStateCounter;
536
- return that._pInitialStateApplied
537
- .then(function() {
538
- return that.collectResults(that.base.viewState.adaptStateControls);
539
- })
540
- .then(function(aControls) {
541
- return Promise.all(
542
- aControls
543
- .filter(function(oControl) {
544
- return oControl && oControl.isA && oControl.isA("sap.ui.base.ManagedObject");
545
- })
546
- .map(function(oControl) {
547
- return that.retrieveControlState(oControl).then(function(vResult) {
548
- return {
549
- key: that.getStateKey(oControl),
550
- value: vResult
551
- };
552
- });
553
- })
554
- );
555
- })
556
- .then(function(aResolvedStates) {
557
- return aResolvedStates.reduce(function(oStates, mState) {
558
- var oCurrentState = {};
559
- oCurrentState[mState.key] = mState.value;
560
- return mergeObjects(oStates, oCurrentState);
561
- }, {});
562
- })
563
- .then(function(oViewState) {
564
- return Promise.resolve(that._retrieveAdditionalStates()).then(function(mAdditionalStates) {
565
- if (mAdditionalStates && Object.keys(mAdditionalStates).length) {
566
- oViewState[ADDITIONAL_STATES_KEY] = mAdditionalStates;
567
- }
568
- return oViewState;
569
- });
570
- })
571
- .finally(function() {
572
- --that._iRetrievingStateCounter;
573
- })
574
- .then(function(oViewState) {
575
- return that._iRetrievingStateCounter === 0 ? oViewState : undefined;
576
- });
577
- },
578
-
579
- /**
580
- * Extend the map of additional states (not control bound) to be added to the current view state of the given view.
581
- *
582
- * This function is meant to be individually overridden by consuming controllers, but not to be called directly.
583
- * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.
584
- *
585
- * @param {object} mAdditionalStates The additional state
586
- *
587
- * @alias sap.fe.core.controllerextensions.ViewState#retrieveAdditionalStates
588
- * @protected
589
- */
590
- retrieveAdditionalStates: function(mAdditionalStates) {
591
- // to be overridden if needed
592
- },
593
-
594
- /**
595
- * Returns a map of additional states (not control bound) to be added to the current view state of the given view.
596
- *
597
- * @returns {object | Promise<object>} Additional view states
598
- */
599
- _retrieveAdditionalStates: function() {
600
- var mAdditionalStates = {};
601
- this.base.viewState.retrieveAdditionalStates(mAdditionalStates);
602
- return mAdditionalStates;
603
- },
604
-
605
- /**
606
- * Returns the current state for the given control.
607
- *
608
- * @param {sap.ui.base.ManagedObject} oControl The object to get the state for
609
- * @returns {Promise<object>} The state for the given control
610
- */
611
- retrieveControlState: function(oControl) {
612
- var aControlStateHandlers = this.getControlStateHandler(oControl);
613
- return Promise.all(
614
- aControlStateHandlers.map(function(mControlStateHandler) {
615
- if (typeof mControlStateHandler.retrieve !== "function") {
616
- throw new Error(
617
- "controlStateHandler.retrieve is not a function for control: " + oControl.getMetadata().getName()
618
- );
619
- }
620
- return mControlStateHandler.retrieve.call(this, oControl);
621
- })
622
- ).then(function(aStates) {
623
- return aStates.reduce(function(oFinalState, oCurrentState) {
624
- return mergeObjects(oFinalState, oCurrentState);
625
- }, {});
626
- });
627
- },
628
-
629
- /**
630
- * Defines whether the view state should only be applied once initially.
631
- *
632
- * This function is meant to be individually overridden by consuming controllers, but not to be called directly.
633
- * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.Instead}.
634
- *
635
- * Important:
636
- * You should only override this method for custom pages and not for the standard ListReportPage and ObjectPage!
637
- *
638
- * @returns {boolean} If <code>true</code>, only the initial view state is applied once,
639
- * else any new view state is also applied on follow-up calls (default)
640
- *
641
- * @alias sap.fe.core.controllerextensions.ViewState#applyInitialStateOnly
642
- * @protected
643
- */
644
- applyInitialStateOnly: function() {
645
- return true;
646
- },
647
- /**
648
- * Applies the given view state to this extensions view.
649
- *
650
- * @param {object} oViewState The view state to apply (can be undefined)
651
- * @param {object} oNavParameter The current navigation parameter
652
- * @param {sap.fe.navigation.NavType} oNavParameter.navigationType The actual navigation type
653
- * @param {object} [oNavParameter.selectionVariant] The selectionVariant from the navigation
654
- * @param {object} [oNavParameter.selectionVariantDefaults] The selectionVariant defaults from the navigation
655
- * @param {boolean} [oNavParameter.requiresStandardVariant] Defines whether standard variant must be used in VM
656
- *
657
- * @returns {Promise} Promise for async state handling
658
- *
659
- * @alias sap.fe.core.controllerextensions.ViewState#applyViewState
660
- * @public
661
- */
662
- applyViewState: function(oViewState, oNavParameter) {
663
- var that = this;
664
- if (this.base.viewState.applyInitialStateOnly() && this._getInitialStateApplied()) {
665
- return Promise.resolve();
666
- }
667
- return this.collectResults(this.base.viewState.onBeforeStateApplied)
668
- .then(function() {
669
- return that.collectResults(that.base.viewState.adaptStateControls);
670
- })
671
- .then(function(aControls) {
672
- var oPromiseChain = Promise.resolve();
673
- aControls
674
- .filter(function(oControl) {
675
- return oControl && oControl.isA && oControl.isA("sap.ui.base.ManagedObject");
676
- })
677
- .forEach(function(oControl) {
678
- var sKey = that.getStateKey(oControl);
679
- oPromiseChain = oPromiseChain.then(
680
- that.applyControlState.bind(that, oControl, oViewState ? oViewState[sKey] : undefined, oNavParameter)
681
- );
682
- });
683
- return oPromiseChain;
684
- })
685
- .then(function() {
686
- if (oNavParameter.navigationType === NavType.iAppState) {
687
- return that.collectResults(
688
- that.base.viewState.applyAdditionalStates,
689
- oViewState ? oViewState[ADDITIONAL_STATES_KEY] : undefined
690
- );
691
- } else {
692
- return that.collectResults(that.base.viewState.applyNavigationParameters, oNavParameter);
693
- }
694
- })
695
- .finally(function() {
696
- return that.collectResults(that.base.viewState.onAfterStateApplied).then(that._setInitialStateApplied.bind(that));
697
- });
698
- },
699
-
700
- _checkIfVariantIdIsAvailable: function(oVM, sVariantId) {
701
- var aVariants = oVM.getVariants(),
702
- bIsControlStateVariantAvailable = false;
703
- aVariants.forEach(function(oVariant) {
704
- if (oVariant.key === sVariantId) {
705
- bIsControlStateVariantAvailable = true;
706
- }
707
- });
708
- return bIsControlStateVariantAvailable;
709
- },
710
-
711
- _setInitialStateApplied: function() {
712
- if (this._pInitialStateAppliedResolve) {
713
- var pInitialStateAppliedResolve = this._pInitialStateAppliedResolve;
714
- delete this._pInitialStateAppliedResolve;
715
- pInitialStateAppliedResolve();
716
- }
717
- },
718
-
719
- _getInitialStateApplied: function() {
720
- return !this._pInitialStateAppliedResolve;
721
- },
722
-
723
- /**
724
- * Hook to react before a state for given view is applied.
725
- *
726
- * This function is meant to be individually overridden by consuming controllers, but not to be called directly.
727
- * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.
728
- *
729
- * @param {Promise} aPromises Extensible array of promises to be resolved before continuing
730
- *
731
- * @alias sap.fe.core.controllerextensions.ViewState#onBeforeStateApplied
732
- * @protected
733
- */
734
- onBeforeStateApplied: function(aPromises) {},
735
-
736
- /**
737
- * Hook to react when state for given view was applied.
738
- *
739
- * This function is meant to be individually overridden by consuming controllers, but not to be called directly.
740
- * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.
741
- *
742
- * @param {Promise} aPromises Extensible array of promises to be resolved before continuing
743
- *
744
- * @alias sap.fe.core.controllerextensions.ViewState#onAfterStateApplied
745
- * @protected
746
- */
747
- onAfterStateApplied: function(aPromises) {},
748
-
749
- /**
750
- * Applying additional, not control related, states - is called only if navigation type is iAppState.
751
- *
752
- * This function is meant to be individually overridden by consuming controllers, but not to be called directly.
753
- * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.
754
- *
755
- * @param {object} oViewState The current view state
756
- * @param {Promise} aPromises Extensible array of promises to be resolved before continuing
757
- *
758
- * @alias sap.fe.core.controllerextensions.ViewState#applyAdditionalStates
759
- * @protected
760
- */
761
- applyAdditionalStates: function(oViewState, aPromises) {
762
- // to be overridden if needed
763
- },
764
-
765
- /**
766
- * Apply navigation parameters - is called only if navigation type is not iAppState.
767
- *
768
- * This function is meant to be individually overridden by consuming controllers, but not to be called directly.
769
- * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.
770
- *
771
- * @param {object} oNavParameter The current navigation parameter
772
- * @param {sap.fe.navigation.NavType} oNavParameter.navigationType The actual navigation type
773
- * @param {object} [oNavParameter.selectionVariant] The selectionVariant from the navigation
774
- * @param {object} [oNavParameter.selectionVariantDefaults] The selectionVariant defaults from the navigation
775
- * @param {boolean} [oNavParameter.requiresStandardVariant] Defines whether standard variant must be used in VM
776
- * @param {Promise} aPromises Extensible array of promises to be resolved before continuing
777
- *
778
- * @alias sap.fe.core.controllerextensions.ViewState#applyNavigationParameters
779
- * @protected
780
- */
781
- applyNavigationParameters: function(oNavParameter, aPromises) {
782
- // to be overridden if needed
783
- },
784
-
785
- /**
786
- * Applying the given state to the given control.
787
- *
788
- * @param {sap.ui.base.ManagedObject} oControl The object to apply the given state
789
- * @param {object} oControlState The state for the given control
790
- * @param {object} oNavParameters The current navigation parameters
791
- * @returns {any} Return a promise for async state handling
792
- */
793
- applyControlState: function(oControl, oControlState, oNavParameters) {
794
- var aControlStateHandlers = this.getControlStateHandler(oControl),
795
- oPromiseChain = Promise.resolve(),
796
- that = this;
797
- aControlStateHandlers.forEach(function(mControlStateHandler) {
798
- if (typeof mControlStateHandler.apply !== "function") {
799
- throw new Error("controlStateHandler.apply is not a function for control: " + oControl.getMetadata().getName());
800
- }
801
- oPromiseChain = oPromiseChain.then(mControlStateHandler.apply.bind(that, oControl, oControlState, oNavParameters));
802
- });
803
- return oPromiseChain;
804
- }
805
- });
806
-
807
- return ViewState;
808
- }
809
- );
5
+ sap.ui.define(["sap/ui/core/mvc/ControllerExtension", "sap/ui/core/mvc/OverrideExecution", "sap/base/Log", "sap/base/util/merge", "sap/ui/fl/apply/api/ControlVariantApplyAPI", "sap/ui/mdc/p13n/StateUtil", "sap/fe/navigation/library", "sap/fe/core/CommonUtils", "sap/fe/core/helpers/KeepAliveHelper", "sap/fe/core/helpers/ModelHelper", "sap/fe/core/helpers/ClassSupport", "sap/fe/core/controllerextensions/ControllerExtensionMetadata"], function (ControllerExtension, OverrideExecution, Log, mergeObjects, ControlVariantApplyAPI, StateUtil, NavLibrary, CommonUtils, KeepAliveHelper, ModelHelper, ClassSupport, ControllerExtensionMetadata) {
6
+ "use strict";
7
+
8
+ var _dec, _dec2, _dec3, _dec4, _dec5, _dec6, _dec7, _dec8, _dec9, _dec10, _dec11, _dec12, _dec13, _class, _class2;
9
+
10
+ var UI5Class = ClassSupport.UI5Class;
11
+ var Public = ClassSupport.Public;
12
+ var Private = ClassSupport.Private;
13
+ var Final = ClassSupport.Final;
14
+ var Extensible = ClassSupport.Extensible;
15
+
16
+ function _get() { if (typeof Reflect !== "undefined" && Reflect.get) { _get = Reflect.get; } else { _get = function _get(target, property, receiver) { var base = _superPropBase(target, property); if (!base) return; var desc = Object.getOwnPropertyDescriptor(base, property); if (desc.get) { return desc.get.call(arguments.length < 3 ? target : receiver); } return desc.value; }; } return _get.apply(this, arguments); }
17
+
18
+ function _superPropBase(object, property) { while (!Object.prototype.hasOwnProperty.call(object, property)) { object = _getPrototypeOf(object); if (object === null) break; } return object; }
19
+
20
+ function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
21
+
22
+ function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
23
+
24
+ function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
25
+
26
+ function _applyDecoratedDescriptor(target, property, decorators, descriptor, context) { var desc = {}; Object.keys(descriptor).forEach(function (key) { desc[key] = descriptor[key]; }); desc.enumerable = !!desc.enumerable; desc.configurable = !!desc.configurable; if ('value' in desc || desc.initializer) { desc.writable = true; } desc = decorators.slice().reverse().reduce(function (desc, decorator) { return decorator(target, property, desc) || desc; }, desc); if (context && desc.initializer !== void 0) { desc.value = desc.initializer ? desc.initializer.call(context) : void 0; desc.initializer = undefined; } if (desc.initializer === void 0) { Object.defineProperty(target, property, desc); desc = null; } return desc; }
27
+
28
+ // additionalStates are stored next to control IDs, so name clash avoidance needed. Fortunately IDs have restrictions:
29
+ // "Allowed is a sequence of characters (capital/lowercase), digits, underscores, dashes, points and/or colons."
30
+ // Therefore adding a symbol like # or @
31
+ var ADDITIONAL_STATES_KEY = "#additionalStates",
32
+ NavType = NavLibrary.NavType; ///////////////////////////////////////////////////////////////////
33
+ // methods to retrieve & apply states for the different controls //
34
+ ///////////////////////////////////////////////////////////////////
35
+
36
+ var _mControlStateHandlerMap = {
37
+ "sap.ui.fl.variants.VariantManagement": {
38
+ retrieve: function (oVM) {
39
+ return {
40
+ "variantId": oVM.getCurrentVariantKey()
41
+ };
42
+ },
43
+ apply: function (oVM, oControlState) {
44
+ if (oControlState && oControlState.variantId !== undefined && oControlState.variantId !== oVM.getCurrentVariantKey()) {
45
+ var sVariantReference = this._checkIfVariantIdIsAvailable(oVM, oControlState.variantId) ? oControlState.variantId : oVM.getStandardVariantKey();
46
+ return ControlVariantApplyAPI.activateVariant({
47
+ element: oVM,
48
+ variantReference: sVariantReference
49
+ });
50
+ }
51
+ }
52
+ },
53
+ "sap.m.IconTabBar": {
54
+ retrieve: function (oTabBar) {
55
+ return {
56
+ selectedKey: oTabBar.getSelectedKey()
57
+ };
58
+ },
59
+ apply: function (oTabBar, oControlState) {
60
+ if (oControlState && oControlState.selectedKey) {
61
+ var oSelectedItem = oTabBar.getItems().find(function (oItem) {
62
+ return oItem.getKey() === oControlState.selectedKey;
63
+ });
64
+
65
+ if (oSelectedItem) {
66
+ oTabBar.setSelectedItem(oSelectedItem);
67
+ }
68
+ }
69
+ }
70
+ },
71
+ "sap.ui.mdc.FilterBar": {
72
+ retrieve: function (oFilterBar) {
73
+ return StateUtil.retrieveExternalState(oFilterBar).then(function (mFilterBarState) {
74
+ // remove sensitive or view state irrelevant fields
75
+ var aPropertiesInfo = oFilterBar.getPropertyInfoSet(),
76
+ mFilter = mFilterBarState.filter || {};
77
+ aPropertiesInfo.filter(function (oPropertyInfo) {
78
+ return mFilter[oPropertyInfo.path] && (oPropertyInfo.removeFromAppState || mFilter[oPropertyInfo.path].length === 0);
79
+ }).forEach(function (oPropertyInfo) {
80
+ delete mFilter[oPropertyInfo.path];
81
+ });
82
+ return mFilterBarState;
83
+ });
84
+ },
85
+ apply: function (oFilterBar, oControlState) {
86
+ if (oControlState) {
87
+ return StateUtil.applyExternalState(oFilterBar, oControlState);
88
+ }
89
+ }
90
+ },
91
+ "sap.ui.mdc.Table": {
92
+ retrieve: function (oTable) {
93
+ return StateUtil.retrieveExternalState(oTable);
94
+ },
95
+ apply: function (oTable, oControlState) {
96
+ if (oControlState) {
97
+ return StateUtil.applyExternalState(oTable, oControlState);
98
+ }
99
+ },
100
+ refreshBinding: function (oTable) {
101
+ var oTableBinding = oTable.getRowBinding();
102
+
103
+ if (oTableBinding) {
104
+ var oRootBinding = oTableBinding.getRootBinding();
105
+
106
+ if (oRootBinding === oTableBinding) {
107
+ // absolute binding
108
+ oTableBinding.refresh();
109
+ } else {
110
+ // relative binding
111
+ var oHeaderContext = oTableBinding.getHeaderContext();
112
+ var sGroupId = oTableBinding.getGroupId();
113
+
114
+ if (oHeaderContext) {
115
+ oHeaderContext.requestSideEffects([{
116
+ $NavigationPropertyPath: ""
117
+ }], sGroupId);
118
+ }
119
+ }
120
+ } else {
121
+ Log.info("Table: " + oTable.getId() + " was not refreshed. No binding found!");
122
+ }
123
+ }
124
+ },
125
+ "sap.uxap.ObjectPageLayout": {
126
+ retrieve: function (oOPLayout) {
127
+ return {
128
+ selectedSection: oOPLayout.getSelectedSection()
129
+ };
130
+ },
131
+ apply: function (oOPLayout, oControlState) {
132
+ oControlState && oOPLayout.setSelectedSection(oControlState.selectedSection);
133
+ },
134
+ refreshBinding: function (oOPLayout) {
135
+ var oBindingContext = oOPLayout.getBindingContext();
136
+ var oBinding = oBindingContext && oBindingContext.getBinding();
137
+
138
+ if (oBinding) {
139
+ var sMetaPath = ModelHelper.getMetaPathForContext(oBindingContext);
140
+ var sStrategy = KeepAliveHelper.getControlRefreshStrategyForContextPath(oOPLayout, sMetaPath);
141
+
142
+ if (sStrategy === "self") {
143
+ // Refresh main context and 1-1 navigation properties or OP
144
+ var oModel = oBindingContext.getModel(),
145
+ oMetaModel = oModel.getMetaModel(),
146
+ oNavigationProperties = CommonUtils.getContextPathProperties(oMetaModel, sMetaPath, {
147
+ $kind: "NavigationProperty"
148
+ }) || {},
149
+ aNavPropertiesToRequest = Object.keys(oNavigationProperties).reduce(function (aPrev, sNavProp) {
150
+ if (oNavigationProperties[sNavProp].$isCollection !== true) {
151
+ aPrev.push({
152
+ $NavigationPropertyPath: sNavProp
153
+ });
154
+ }
155
+
156
+ return aPrev;
157
+ }, []),
158
+ aProperties = [{
159
+ $PropertyPath: "*"
160
+ }],
161
+ sGroupId = oBinding.getGroupId();
162
+ oBindingContext.requestSideEffects(aProperties.concat(aNavPropertiesToRequest), sGroupId);
163
+ } else if (sStrategy === "includingDependents") {
164
+ // Complete refresh
165
+ oBinding.refresh();
166
+ }
167
+ } else {
168
+ Log.info("ObjectPage: " + oOPLayout.getId() + " was not refreshed. No binding found!");
169
+ }
170
+ }
171
+ },
172
+ "sap.fe.macros.table.QuickFilterContainer": {
173
+ retrieve: function (oQuickFilter) {
174
+ return {
175
+ selectedKey: oQuickFilter.getSelectorKey()
176
+ };
177
+ },
178
+ apply: function (oQuickFilter, oControlState) {
179
+ oControlState && oQuickFilter.setSelectorKey(oControlState.selectedKey);
180
+ }
181
+ },
182
+ "sap.m.SegmentedButton": {
183
+ retrieve: function (oSegmentedButton) {
184
+ return {
185
+ selectedKey: oSegmentedButton.getSelectedKey()
186
+ };
187
+ },
188
+ apply: function (oSegmentedButton, oControlState) {
189
+ oControlState && oSegmentedButton.setSelectedKey(oControlState.selectedKey);
190
+ }
191
+ },
192
+ "sap.m.Select": {
193
+ retrieve: function (oSelect) {
194
+ return {
195
+ selectedKey: oSelect.getSelectedKey()
196
+ };
197
+ },
198
+ apply: function (oSelect, oControlState) {
199
+ oControlState && oSelect.setSelectedKey(oControlState.selectedKey);
200
+ }
201
+ },
202
+ "sap.f.DynamicPage": {
203
+ retrieve: function (oDynamicPage) {
204
+ return {
205
+ headerExpanded: oDynamicPage.getHeaderExpanded()
206
+ };
207
+ },
208
+ apply: function (oDynamicPage, oControlState) {
209
+ oControlState && oDynamicPage.setHeaderExpanded(oControlState.headerExpanded);
210
+ }
211
+ },
212
+ "sap.ui.core.mvc.View": {
213
+ retrieve: function (oView) {
214
+ var oController = oView.getController();
215
+
216
+ if (oController && oController.viewState) {
217
+ return oController.viewState.retrieveViewState(oController.viewState);
218
+ }
219
+
220
+ return {};
221
+ },
222
+ apply: function (oView, oControlState, oNavParameters) {
223
+ var oController = oView.getController();
224
+
225
+ if (oController && oController.viewState) {
226
+ return oController.viewState.applyViewState(oControlState, oNavParameters);
227
+ }
228
+ },
229
+ refreshBinding: function (oView) {
230
+ var oController = oView.getController();
231
+
232
+ if (oController && oController.viewState) {
233
+ return oController.viewState.refreshViewBindings();
234
+ }
235
+ }
236
+ },
237
+ "sap.ui.core.ComponentContainer": {
238
+ retrieve: function (oComponentContainer) {
239
+ var oComponent = oComponentContainer.getComponentInstance();
240
+
241
+ if (oComponent) {
242
+ return this.retrieveControlState(oComponent.getRootControl());
243
+ }
244
+
245
+ return {};
246
+ },
247
+ apply: function (oComponentContainer, oControlState, oNavParameters) {
248
+ var oComponent = oComponentContainer.getComponentInstance();
249
+
250
+ if (oComponent) {
251
+ return this.applyControlState(oComponent.getRootControl(), oControlState, oNavParameters);
252
+ }
253
+ }
254
+ }
255
+ };
256
+ /**
257
+ * A controller extension offering hooks for state handling
258
+ *
259
+ * If you need to maintain a specific state for your application, you can use the controller extension.
260
+ *
261
+ * @hideconstructor
262
+ * @public
263
+ * @since 1.85.0
264
+ */
265
+
266
+ var ViewState = (_dec = UI5Class("sap.fe.core.controllerextensions.ViewState", ControllerExtensionMetadata), _dec2 = Extensible(OverrideExecution.After), _dec3 = Extensible(OverrideExecution.After), _dec4 = Extensible(OverrideExecution.After), _dec5 = Extensible(OverrideExecution.After), _dec6 = Extensible(OverrideExecution.After), _dec7 = Extensible(OverrideExecution.After), _dec8 = Extensible(OverrideExecution.After), _dec9 = Extensible(OverrideExecution.Instead), _dec10 = Extensible(OverrideExecution.After), _dec11 = Extensible(OverrideExecution.After), _dec12 = Extensible(OverrideExecution.After), _dec13 = Extensible(OverrideExecution.After), _dec(_class = (_class2 = /*#__PURE__*/function (_ControllerExtension) {
267
+ _inherits(ViewState, _ControllerExtension);
268
+
269
+ /**
270
+ * Constructor.
271
+ */
272
+ function ViewState() {
273
+ var _this;
274
+
275
+ _this = _ControllerExtension.call(this) || this;
276
+ _this._iRetrievingStateCounter = 0;
277
+ _this._pInitialStateApplied = new Promise(function (resolve) {
278
+ _this._pInitialStateAppliedResolve = resolve;
279
+ });
280
+ return _this;
281
+ }
282
+ /**
283
+ * @private
284
+ * @name sap.fe.core.controllerextensions.ViewState.getMetadata
285
+ * @function
286
+ */
287
+
288
+ /**
289
+ * @private
290
+ * @name sap.fe.core.controllerextensions.ViewState.extend
291
+ * @function
292
+ */
293
+
294
+
295
+ var _proto = ViewState.prototype;
296
+
297
+ _proto.refreshViewBindings = function refreshViewBindings() {
298
+ var _this2 = this;
299
+
300
+ return this.collectResults(this.base.viewState.adaptBindingRefreshControls).then(function (aControls) {
301
+ var oPromiseChain = Promise.resolve();
302
+ aControls.filter(function (oControl) {
303
+ return oControl && oControl.isA && oControl.isA("sap.ui.base.ManagedObject");
304
+ }).forEach(function (oControl) {
305
+ oPromiseChain = oPromiseChain.then(_this2.refreshControlBinding.bind(_this2, oControl));
306
+ });
307
+ return oPromiseChain;
308
+ });
309
+ }
310
+ /**
311
+ * This function should add all controls relevant for refreshing to the provided control array.
312
+ *
313
+ * This function is meant to be individually overridden by consuming controllers, but not to be called directly.
314
+ * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.
315
+ * @param {Array<sap.ui.base.ManagedObject>} aCollectedControls The collected controls
316
+ * @alias sap.fe.core.controllerextensions.ViewState#adaptBindingRefreshControls
317
+ * @protected
318
+ */
319
+ ;
320
+
321
+ _proto. // eslint-disable-next-line @typescript-eslint/no-unused-vars
322
+ adaptBindingRefreshControls = function adaptBindingRefreshControls(aCollectedControls) {// to be overriden
323
+ };
324
+
325
+ _proto.refreshControlBinding = function refreshControlBinding(oControl) {
326
+ var oControlRefreshBindingHandler = this.getControlRefreshBindingHandler(oControl);
327
+ var oPromiseChain = Promise.resolve();
328
+
329
+ if (typeof oControlRefreshBindingHandler.refreshBinding !== "function") {
330
+ Log.info("refreshBinding handler for control: " + oControl.getMetadata().getName() + " is not provided");
331
+ } else {
332
+ oPromiseChain = oPromiseChain.then(oControlRefreshBindingHandler.refreshBinding.bind(this, oControl));
333
+ }
334
+
335
+ return oPromiseChain;
336
+ }
337
+ /**
338
+ * Returns a map of <code>refreshBinding</code> function for a certain control.
339
+ *
340
+ * @param {sap.ui.base.ManagedObject} oControl The control to get state handler for
341
+ * @returns {object} A plain object with one function: <code>refreshBinding</code>
342
+ */
343
+ ;
344
+
345
+ _proto.getControlRefreshBindingHandler = function getControlRefreshBindingHandler(oControl) {
346
+ var oRefreshBindingHandler = {};
347
+
348
+ if (oControl) {
349
+ for (var sType in _mControlStateHandlerMap) {
350
+ if (oControl.isA(sType)) {
351
+ // pass only the refreshBinding handler in an object so that :
352
+ // 1. Application has access only to refreshBinding and not apply and reterive at this stage
353
+ // 2. Application modifications to the object will be reflected here (as we pass by reference)
354
+ oRefreshBindingHandler["refreshBinding"] = _mControlStateHandlerMap[sType].refreshBinding || {};
355
+ break;
356
+ }
357
+ }
358
+ }
359
+
360
+ this.base.viewState.adaptBindingRefreshHandler(oControl, oRefreshBindingHandler);
361
+ return oRefreshBindingHandler;
362
+ }
363
+ /**
364
+ * Customize the <code>refreshBinding</code> function for a certain control.
365
+ *
366
+ * This function is meant to be individually overridden by consuming controllers, but not to be called directly.
367
+ * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.
368
+ *
369
+ * @param {sap.ui.base.ManagedObject} oControl The control for which the refresh handler is adapted.
370
+ * @param {Array<object>} oControlHandler A plain object which can have one function: <code>refreshBinding</code>
371
+ *
372
+ * @alias sap.fe.core.controllerextensions.ViewState#adaptBindingRefreshHandler
373
+ * @protected
374
+ */
375
+ ;
376
+
377
+ _proto. // eslint-disable-next-line @typescript-eslint/no-unused-vars
378
+ adaptBindingRefreshHandler = function adaptBindingRefreshHandler(oControl, oControlHandler) {// to be overriden
379
+ }
380
+ /**
381
+ * Called when the application is suspended due to keep-alive mode.
382
+ *
383
+ * @alias sap.fe.core.controllerextensions.ViewState#onSuspend
384
+ * @public
385
+ */
386
+ ;
387
+
388
+ _proto.onSuspend = function onSuspend() {// to be overriden
389
+ }
390
+ /**
391
+ * Called when the application is restored due to keep-alive mode.
392
+ *
393
+ * @alias sap.fe.core.controllerextensions.ViewState#onRestore
394
+ * @public
395
+ */
396
+ ;
397
+
398
+ _proto.onRestore = function onRestore() {// to be overriden
399
+ }
400
+ /**
401
+ * Destructor method for objects.
402
+ */
403
+ ;
404
+
405
+ _proto.destroy = function destroy() {
406
+ delete this._pInitialStateAppliedResolve;
407
+
408
+ _get(_getPrototypeOf(ViewState.prototype), "destroy", this).call(this);
409
+ }
410
+ /**
411
+ * Helper function to enable multi override. It is adding an additional parameter (array) to the provided
412
+ * function (and its parameters), that will be evaluated via <code>Promise.all</code>.
413
+ *
414
+ * @param {Function} fnCall The function to be called
415
+ * @param args
416
+ * @returns {Promise} A promise to be resolved with the result of all overrides
417
+ */
418
+ ;
419
+
420
+ _proto.collectResults = function collectResults(fnCall) {
421
+ var aResults = [];
422
+
423
+ for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
424
+ args[_key - 1] = arguments[_key];
425
+ }
426
+
427
+ args.push(aResults);
428
+ fnCall.apply(this, args);
429
+ return Promise.all(aResults);
430
+ }
431
+ /**
432
+ * Customize the <code>retrieve</code> and <code>apply</code> functions for a certain control.
433
+ *
434
+ * This function is meant to be individually overridden by consuming controllers, but not to be called directly.
435
+ * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.
436
+ *
437
+ * @param {sap.ui.base.ManagedObject} oControl The control to get state handler for
438
+ * @param {Array<object>} aControlHandler A list of plain objects with two functions: <code>retrieve</code> and <code>apply</code>
439
+ *
440
+ * @alias sap.fe.core.controllerextensions.ViewState#adaptControlStateHandler
441
+ * @protected
442
+ */
443
+ ;
444
+
445
+ _proto. // eslint-disable-next-line @typescript-eslint/no-unused-vars
446
+ adaptControlStateHandler = function adaptControlStateHandler(oControl, aControlHandler) {// to be overridden if needed
447
+ }
448
+ /**
449
+ * Returns a map of <code>retrieve</code> and <code>apply</code> functions for a certain control.
450
+ *
451
+ * @param {sap.ui.base.ManagedObject} oControl The control to get state handler for
452
+ * @returns {object} A plain object with two functions: <code>retrieve</code> and <code>apply</code>
453
+ */
454
+ ;
455
+
456
+ _proto.getControlStateHandler = function getControlStateHandler(oControl) {
457
+ var aInternalControlStateHandler = [],
458
+ aCustomControlStateHandler = [];
459
+
460
+ if (oControl) {
461
+ for (var sType in _mControlStateHandlerMap) {
462
+ if (oControl.isA(sType)) {
463
+ // avoid direct manipulation of internal _mControlStateHandlerMap
464
+ aInternalControlStateHandler.push(Object.assign({}, _mControlStateHandlerMap[sType]));
465
+ break;
466
+ }
467
+ }
468
+ }
469
+
470
+ this.base.viewState.adaptControlStateHandler(oControl, aCustomControlStateHandler);
471
+ return aInternalControlStateHandler.concat(aCustomControlStateHandler);
472
+ }
473
+ /**
474
+ * This function should add all controls for given view that should be considered for the state handling to the provided control array.
475
+ *
476
+ * This function is meant to be individually overridden by consuming controllers, but not to be called directly.
477
+ * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.
478
+ * @param {Array<sap.ui.base.ManagedObject>} aCollectedControls The collected controls
479
+ * @alias sap.fe.core.controllerextensions.ViewState#adaptStateControls
480
+ * @protected
481
+ */
482
+ ;
483
+
484
+ _proto. // eslint-disable-next-line @typescript-eslint/no-unused-vars
485
+ adaptStateControls = function adaptStateControls(aCollectedControls) {// to be overridden if needed
486
+ }
487
+ /**
488
+ * Returns the key to be used for given control.
489
+ *
490
+ * @param {sap.ui.base.ManagedObject} oControl The control to get state key for
491
+ * @returns {string} The key to be used for storing the controls state
492
+ */
493
+ ;
494
+
495
+ _proto.getStateKey = function getStateKey(oControl) {
496
+ return this.getView().getLocalId(oControl.getId()) || oControl.getId();
497
+ }
498
+ /**
499
+ * Retrieve the view state of this extensions view.
500
+ * When this function is called more than once before finishing, all but the final response will resolve to <code>undefined</code>.
501
+ *
502
+ * @returns {Promise} A promise resolving the view state
503
+ *
504
+ * @alias sap.fe.core.controllerextensions.ViewState#retrieveViewState
505
+ * @public
506
+ */
507
+ ;
508
+
509
+ _proto.retrieveViewState = function retrieveViewState() {
510
+ var _this3 = this;
511
+
512
+ ++this._iRetrievingStateCounter;
513
+ return this._pInitialStateApplied.then(function () {
514
+ return _this3.collectResults(_this3.base.viewState.adaptStateControls);
515
+ }).then(function (aControls) {
516
+ return Promise.all(aControls.filter(function (oControl) {
517
+ return oControl && oControl.isA && oControl.isA("sap.ui.base.ManagedObject");
518
+ }).map(function (oControl) {
519
+ return _this3.retrieveControlState(oControl).then(function (vResult) {
520
+ return {
521
+ key: _this3.getStateKey(oControl),
522
+ value: vResult
523
+ };
524
+ });
525
+ }));
526
+ }).then(function (aResolvedStates) {
527
+ return aResolvedStates.reduce(function (oStates, mState) {
528
+ var oCurrentState = {};
529
+ oCurrentState[mState.key] = mState.value;
530
+ return mergeObjects(oStates, oCurrentState);
531
+ }, {});
532
+ }).then(function (oViewState) {
533
+ return Promise.resolve(_this3._retrieveAdditionalStates()).then(function (mAdditionalStates) {
534
+ if (mAdditionalStates && Object.keys(mAdditionalStates).length) {
535
+ oViewState[ADDITIONAL_STATES_KEY] = mAdditionalStates;
536
+ }
537
+
538
+ return oViewState;
539
+ });
540
+ }).finally(function () {
541
+ --_this3._iRetrievingStateCounter;
542
+ }).then(function (oViewState) {
543
+ return _this3._iRetrievingStateCounter === 0 ? oViewState : undefined;
544
+ });
545
+ }
546
+ /**
547
+ * Extend the map of additional states (not control bound) to be added to the current view state of the given view.
548
+ *
549
+ * This function is meant to be individually overridden by consuming controllers, but not to be called directly.
550
+ * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.
551
+ *
552
+ * @param {object} mAdditionalStates The additional state
553
+ *
554
+ * @alias sap.fe.core.controllerextensions.ViewState#retrieveAdditionalStates
555
+ * @protected
556
+ */
557
+ ;
558
+
559
+ _proto. // eslint-disable-next-line @typescript-eslint/no-unused-vars
560
+ retrieveAdditionalStates = function retrieveAdditionalStates(mAdditionalStates) {// to be overridden if needed
561
+ }
562
+ /**
563
+ * Returns a map of additional states (not control bound) to be added to the current view state of the given view.
564
+ *
565
+ * @returns {object | Promise<object>} Additional view states
566
+ */
567
+ ;
568
+
569
+ _proto._retrieveAdditionalStates = function _retrieveAdditionalStates() {
570
+ var mAdditionalStates = {};
571
+ this.base.viewState.retrieveAdditionalStates(mAdditionalStates);
572
+ return mAdditionalStates;
573
+ }
574
+ /**
575
+ * Returns the current state for the given control.
576
+ *
577
+ * @param {sap.ui.base.ManagedObject} oControl The object to get the state for
578
+ * @returns {Promise<object>} The state for the given control
579
+ */
580
+ ;
581
+
582
+ _proto.retrieveControlState = function retrieveControlState(oControl) {
583
+ var _this4 = this;
584
+
585
+ var aControlStateHandlers = this.getControlStateHandler(oControl);
586
+ return Promise.all(aControlStateHandlers.map(function (mControlStateHandler) {
587
+ if (typeof mControlStateHandler.retrieve !== "function") {
588
+ throw new Error("controlStateHandler.retrieve is not a function for control: " + oControl.getMetadata().getName());
589
+ }
590
+
591
+ return mControlStateHandler.retrieve.call(_this4, oControl);
592
+ })).then(function (aStates) {
593
+ return aStates.reduce(function (oFinalState, oCurrentState) {
594
+ return mergeObjects(oFinalState, oCurrentState);
595
+ }, {});
596
+ });
597
+ }
598
+ /**
599
+ * Defines whether the view state should only be applied once initially.
600
+ *
601
+ * This function is meant to be individually overridden by consuming controllers, but not to be called directly.
602
+ * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.Instead}.
603
+ *
604
+ * Important:
605
+ * You should only override this method for custom pages and not for the standard ListReportPage and ObjectPage!
606
+ *
607
+ * @returns {boolean} If <code>true</code>, only the initial view state is applied once,
608
+ * else any new view state is also applied on follow-up calls (default)
609
+ *
610
+ * @alias sap.fe.core.controllerextensions.ViewState#applyInitialStateOnly
611
+ * @protected
612
+ */
613
+ ;
614
+
615
+ _proto.applyInitialStateOnly = function applyInitialStateOnly() {
616
+ return true;
617
+ }
618
+ /**
619
+ * Applies the given view state to this extensions view.
620
+ *
621
+ * @param {object} oViewState The view state to apply (can be undefined)
622
+ * @param {object} oNavParameter The current navigation parameter
623
+ * @param {sap.fe.navigation.NavType} oNavParameter.navigationType The actual navigation type
624
+ * @param {object} oNavParameter.selectionVariant The selectionVariant from the navigation
625
+ * @param {object} oNavParameter.selectionVariantDefaults The selectionVariant defaults from the navigation
626
+ * @param {boolean} oNavParameter.requiresStandardVariant Defines whether standard variant must be used in VM
627
+ *
628
+ * @returns {Promise} Promise for async state handling
629
+ *
630
+ * @alias sap.fe.core.controllerextensions.ViewState#applyViewState
631
+ * @public
632
+ */
633
+ ;
634
+
635
+ _proto.applyViewState = function applyViewState(oViewState, oNavParameter) {
636
+ var _this5 = this;
637
+
638
+ if (this.base.viewState.applyInitialStateOnly() && this._getInitialStateApplied()) {
639
+ return Promise.resolve();
640
+ }
641
+
642
+ return this.collectResults(this.base.viewState.onBeforeStateApplied).then(function () {
643
+ return _this5.collectResults(_this5.base.viewState.adaptStateControls);
644
+ }).then(function (aControls) {
645
+ var oPromiseChain = Promise.resolve();
646
+ aControls.filter(function (oControl) {
647
+ return oControl && oControl.isA && oControl.isA("sap.ui.base.ManagedObject");
648
+ }).forEach(function (oControl) {
649
+ var sKey = _this5.getStateKey(oControl);
650
+
651
+ oPromiseChain = oPromiseChain.then(_this5.applyControlState.bind(_this5, oControl, oViewState ? oViewState[sKey] : undefined, oNavParameter));
652
+ });
653
+ return oPromiseChain;
654
+ }).then(function () {
655
+ if (oNavParameter.navigationType === NavType.iAppState) {
656
+ return _this5.collectResults(_this5.base.viewState.applyAdditionalStates, oViewState ? oViewState[ADDITIONAL_STATES_KEY] : undefined);
657
+ } else {
658
+ return _this5.collectResults(_this5.base.viewState.applyNavigationParameters, oNavParameter);
659
+ }
660
+ }).finally(function () {
661
+ return _this5.collectResults(_this5.base.viewState.onAfterStateApplied).then(_this5._setInitialStateApplied.bind(_this5));
662
+ });
663
+ };
664
+
665
+ _proto._checkIfVariantIdIsAvailable = function _checkIfVariantIdIsAvailable(oVM, sVariantId) {
666
+ var aVariants = oVM.getVariants();
667
+ var bIsControlStateVariantAvailable = false;
668
+ aVariants.forEach(function (oVariant) {
669
+ if (oVariant.key === sVariantId) {
670
+ bIsControlStateVariantAvailable = true;
671
+ }
672
+ });
673
+ return bIsControlStateVariantAvailable;
674
+ };
675
+
676
+ _proto._setInitialStateApplied = function _setInitialStateApplied() {
677
+ if (this._pInitialStateAppliedResolve) {
678
+ var pInitialStateAppliedResolve = this._pInitialStateAppliedResolve;
679
+ delete this._pInitialStateAppliedResolve;
680
+ pInitialStateAppliedResolve();
681
+ }
682
+ };
683
+
684
+ _proto._getInitialStateApplied = function _getInitialStateApplied() {
685
+ return !this._pInitialStateAppliedResolve;
686
+ }
687
+ /**
688
+ * Hook to react before a state for given view is applied.
689
+ *
690
+ * This function is meant to be individually overridden by consuming controllers, but not to be called directly.
691
+ * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.
692
+ *
693
+ * @param {Promise} aPromises Extensible array of promises to be resolved before continuing
694
+ *
695
+ * @alias sap.fe.core.controllerextensions.ViewState#onBeforeStateApplied
696
+ * @protected
697
+ */
698
+ ;
699
+
700
+ _proto. // eslint-disable-next-line @typescript-eslint/no-unused-vars
701
+ onBeforeStateApplied = function onBeforeStateApplied(aPromises) {// to be overriden
702
+ }
703
+ /**
704
+ * Hook to react when state for given view was applied.
705
+ *
706
+ * This function is meant to be individually overridden by consuming controllers, but not to be called directly.
707
+ * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.
708
+ *
709
+ * @param {Promise} aPromises Extensible array of promises to be resolved before continuing
710
+ *
711
+ * @alias sap.fe.core.controllerextensions.ViewState#onAfterStateApplied
712
+ * @protected
713
+ */
714
+ ;
715
+
716
+ _proto. // eslint-disable-next-line @typescript-eslint/no-unused-vars
717
+ onAfterStateApplied = function onAfterStateApplied(aPromises) {// to be overriden
718
+ }
719
+ /**
720
+ * Applying additional, not control related, states - is called only if navigation type is iAppState.
721
+ *
722
+ * This function is meant to be individually overridden by consuming controllers, but not to be called directly.
723
+ * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.
724
+ *
725
+ * @param {object} oViewState The current view state
726
+ * @param {Promise} aPromises Extensible array of promises to be resolved before continuing
727
+ *
728
+ * @alias sap.fe.core.controllerextensions.ViewState#applyAdditionalStates
729
+ * @protected
730
+ */
731
+ ;
732
+
733
+ _proto. // eslint-disable-next-line @typescript-eslint/no-unused-vars
734
+ applyAdditionalStates = function applyAdditionalStates(oViewState, aPromises) {// to be overridden if needed
735
+ }
736
+ /**
737
+ * Apply navigation parameters - is called only if navigation type is not iAppState.
738
+ *
739
+ * This function is meant to be individually overridden by consuming controllers, but not to be called directly.
740
+ * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.
741
+ *
742
+ * @param {object} oNavParameter The current navigation parameter
743
+ * @param {sap.fe.navigation.NavType} oNavParameter.navigationType The actual navigation type
744
+ * @param {object} [oNavParameter.selectionVariant] The selectionVariant from the navigation
745
+ * @param {object} [oNavParameter.selectionVariantDefaults] The selectionVariant defaults from the navigation
746
+ * @param {boolean} [oNavParameter.requiresStandardVariant] Defines whether standard variant must be used in VM
747
+ * @param {Promise} aPromises Extensible array of promises to be resolved before continuing
748
+ *
749
+ * @alias sap.fe.core.controllerextensions.ViewState#applyNavigationParameters
750
+ * @protected
751
+ */
752
+ ;
753
+
754
+ _proto.applyNavigationParameters = function applyNavigationParameters( // eslint-disable-next-line @typescript-eslint/no-unused-vars
755
+ oNavParameter, // eslint-disable-next-line @typescript-eslint/no-unused-vars
756
+ aPromises) {// to be overridden if needed
757
+ }
758
+ /**
759
+ * Applying the given state to the given control.
760
+ *
761
+ * @param {sap.ui.base.ManagedObject} oControl The object to apply the given state
762
+ * @param {object} oControlState The state for the given control
763
+ * @param {object} [oNavParameters] The current navigation parameters
764
+ * @returns {any} Return a promise for async state handling
765
+ */
766
+ ;
767
+
768
+ _proto.applyControlState = function applyControlState(oControl, oControlState, oNavParameters) {
769
+ var _this6 = this;
770
+
771
+ var aControlStateHandlers = this.getControlStateHandler(oControl);
772
+ var oPromiseChain = Promise.resolve();
773
+ aControlStateHandlers.forEach(function (mControlStateHandler) {
774
+ if (typeof mControlStateHandler.apply !== "function") {
775
+ throw new Error("controlStateHandler.apply is not a function for control: " + oControl.getMetadata().getName());
776
+ }
777
+
778
+ oPromiseChain = oPromiseChain.then(mControlStateHandler.apply.bind(_this6, oControl, oControlState, oNavParameters));
779
+ });
780
+ return oPromiseChain;
781
+ };
782
+
783
+ _proto.getInterface = function getInterface() {
784
+ return this;
785
+ };
786
+
787
+ return ViewState;
788
+ }(ControllerExtension), (_applyDecoratedDescriptor(_class2.prototype, "refreshViewBindings", [Public, Final], Object.getOwnPropertyDescriptor(_class2.prototype, "refreshViewBindings"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "adaptBindingRefreshControls", [Public, _dec2], Object.getOwnPropertyDescriptor(_class2.prototype, "adaptBindingRefreshControls"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "refreshControlBinding", [Private, Final], Object.getOwnPropertyDescriptor(_class2.prototype, "refreshControlBinding"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "getControlRefreshBindingHandler", [Private, Final], Object.getOwnPropertyDescriptor(_class2.prototype, "getControlRefreshBindingHandler"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "adaptBindingRefreshHandler", [Public, _dec3], Object.getOwnPropertyDescriptor(_class2.prototype, "adaptBindingRefreshHandler"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "onSuspend", [Public, _dec4], Object.getOwnPropertyDescriptor(_class2.prototype, "onSuspend"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "onRestore", [Public, _dec5], Object.getOwnPropertyDescriptor(_class2.prototype, "onRestore"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "collectResults", [Private, Final], Object.getOwnPropertyDescriptor(_class2.prototype, "collectResults"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "adaptControlStateHandler", [Public, _dec6], Object.getOwnPropertyDescriptor(_class2.prototype, "adaptControlStateHandler"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "getControlStateHandler", [Private, Final], Object.getOwnPropertyDescriptor(_class2.prototype, "getControlStateHandler"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "adaptStateControls", [Public, _dec7], Object.getOwnPropertyDescriptor(_class2.prototype, "adaptStateControls"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "getStateKey", [Public, Final], Object.getOwnPropertyDescriptor(_class2.prototype, "getStateKey"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "retrieveViewState", [Public, Final], Object.getOwnPropertyDescriptor(_class2.prototype, "retrieveViewState"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "retrieveAdditionalStates", [Public, _dec8], Object.getOwnPropertyDescriptor(_class2.prototype, "retrieveAdditionalStates"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "retrieveControlState", [Private, Final], Object.getOwnPropertyDescriptor(_class2.prototype, "retrieveControlState"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "applyInitialStateOnly", [Public, _dec9], Object.getOwnPropertyDescriptor(_class2.prototype, "applyInitialStateOnly"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "applyViewState", [Public, Final], Object.getOwnPropertyDescriptor(_class2.prototype, "applyViewState"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "_checkIfVariantIdIsAvailable", [Private], Object.getOwnPropertyDescriptor(_class2.prototype, "_checkIfVariantIdIsAvailable"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "onBeforeStateApplied", [Public, _dec10], Object.getOwnPropertyDescriptor(_class2.prototype, "onBeforeStateApplied"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "onAfterStateApplied", [Public, _dec11], Object.getOwnPropertyDescriptor(_class2.prototype, "onAfterStateApplied"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "applyAdditionalStates", [Public, _dec12], Object.getOwnPropertyDescriptor(_class2.prototype, "applyAdditionalStates"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "applyNavigationParameters", [Public, _dec13], Object.getOwnPropertyDescriptor(_class2.prototype, "applyNavigationParameters"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "applyControlState", [Private, Final], Object.getOwnPropertyDescriptor(_class2.prototype, "applyControlState"), _class2.prototype)), _class2)) || _class);
789
+ return ViewState;
790
+ }, false);
791
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ViewState.ts"],"names":["ADDITIONAL_STATES_KEY","NavType","NavLibrary","_mControlStateHandlerMap","retrieve","oVM","getCurrentVariantKey","apply","oControlState","variantId","undefined","sVariantReference","_checkIfVariantIdIsAvailable","getStandardVariantKey","ControlVariantApplyAPI","activateVariant","element","variantReference","oTabBar","selectedKey","getSelectedKey","oSelectedItem","getItems","find","oItem","getKey","setSelectedItem","oFilterBar","StateUtil","retrieveExternalState","then","mFilterBarState","aPropertiesInfo","getPropertyInfoSet","mFilter","filter","oPropertyInfo","path","removeFromAppState","length","forEach","applyExternalState","oTable","refreshBinding","oTableBinding","getRowBinding","oRootBinding","getRootBinding","refresh","oHeaderContext","getHeaderContext","sGroupId","getGroupId","requestSideEffects","$NavigationPropertyPath","Log","info","getId","oOPLayout","selectedSection","getSelectedSection","setSelectedSection","oBindingContext","getBindingContext","oBinding","getBinding","sMetaPath","ModelHelper","getMetaPathForContext","sStrategy","KeepAliveHelper","getControlRefreshStrategyForContextPath","oModel","getModel","oMetaModel","getMetaModel","oNavigationProperties","CommonUtils","getContextPathProperties","$kind","aNavPropertiesToRequest","Object","keys","reduce","aPrev","sNavProp","$isCollection","push","aProperties","$PropertyPath","concat","oQuickFilter","getSelectorKey","setSelectorKey","oSegmentedButton","setSelectedKey","oSelect","oDynamicPage","headerExpanded","getHeaderExpanded","setHeaderExpanded","oView","oController","getController","viewState","retrieveViewState","oNavParameters","applyViewState","refreshViewBindings","oComponentContainer","oComponent","getComponentInstance","retrieveControlState","getRootControl","applyControlState","ViewState","UI5Class","ControllerExtensionMetadata","Extensible","OverrideExecution","After","Instead","_iRetrievingStateCounter","_pInitialStateApplied","Promise","resolve","_pInitialStateAppliedResolve","collectResults","base","adaptBindingRefreshControls","aControls","oPromiseChain","oControl","isA","refreshControlBinding","bind","aCollectedControls","oControlRefreshBindingHandler","getControlRefreshBindingHandler","getMetadata","getName","oRefreshBindingHandler","sType","adaptBindingRefreshHandler","oControlHandler","onSuspend","onRestore","destroy","fnCall","aResults","args","all","adaptControlStateHandler","aControlHandler","getControlStateHandler","aInternalControlStateHandler","aCustomControlStateHandler","assign","adaptStateControls","getStateKey","getView","getLocalId","map","vResult","key","value","aResolvedStates","oStates","mState","oCurrentState","mergeObjects","oViewState","_retrieveAdditionalStates","mAdditionalStates","finally","retrieveAdditionalStates","aControlStateHandlers","mControlStateHandler","Error","call","aStates","oFinalState","applyInitialStateOnly","oNavParameter","_getInitialStateApplied","onBeforeStateApplied","sKey","navigationType","iAppState","applyAdditionalStates","applyNavigationParameters","onAfterStateApplied","_setInitialStateApplied","sVariantId","aVariants","getVariants","bIsControlStateVariantAvailable","oVariant","pInitialStateAppliedResolve","aPromises","getInterface","ControllerExtension","Public","Final","Private"],"mappings":"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","sourceRoot":".","sourcesContent":["import ControllerExtension from \"sap/ui/core/mvc/ControllerExtension\";\nimport OverrideExecution from \"sap/ui/core/mvc/OverrideExecution\";\nimport Log from \"sap/base/Log\";\nimport mergeObjects from \"sap/base/util/merge\";\nimport ControlVariantApplyAPI from \"sap/ui/fl/apply/api/ControlVariantApplyAPI\";\nimport StateUtil from \"sap/ui/mdc/p13n/StateUtil\";\nimport NavLibrary from \"sap/fe/navigation/library\";\nimport CommonUtils from \"sap/fe/core/CommonUtils\";\nimport KeepAliveHelper from \"sap/fe/core/helpers/KeepAliveHelper\";\nimport ModelHelper from \"sap/fe/core/helpers/ModelHelper\";\nimport { Extensible, Final, Private, Public, UI5Class } from \"sap/fe/core/helpers/ClassSupport\";\nimport ControllerExtensionMetadata from \"sap/fe/core/controllerextensions/ControllerExtensionMetadata\";\nimport PageController from \"sap/fe/core/PageController\";\nimport ManagedObject from \"sap/ui/base/ManagedObject\";\n// additionalStates are stored next to control IDs, so name clash avoidance needed. Fortunately IDs have restrictions:\n// \"Allowed is a sequence of characters (capital/lowercase), digits, underscores, dashes, points and/or colons.\"\n// Therefore adding a symbol like # or @\nconst ADDITIONAL_STATES_KEY = \"#additionalStates\",\n\tNavType = NavLibrary.NavType;\n///////////////////////////////////////////////////////////////////\n// methods to retrieve & apply states for the different controls //\n///////////////////////////////////////////////////////////////////\nconst _mControlStateHandlerMap: Record<string, any> = {\n\t\"sap.ui.fl.variants.VariantManagement\": {\n\t\tretrieve: function(oVM: any) {\n\t\t\treturn {\n\t\t\t\t\"variantId\": oVM.getCurrentVariantKey()\n\t\t\t};\n\t\t},\n\t\tapply: function(oVM: any, oControlState: any) {\n\t\t\tif (oControlState && oControlState.variantId !== undefined && oControlState.variantId !== oVM.getCurrentVariantKey()) {\n\t\t\t\tconst sVariantReference = this._checkIfVariantIdIsAvailable(oVM, oControlState.variantId)\n\t\t\t\t\t? oControlState.variantId\n\t\t\t\t\t: oVM.getStandardVariantKey();\n\t\t\t\treturn ControlVariantApplyAPI.activateVariant({\n\t\t\t\t\telement: oVM,\n\t\t\t\t\tvariantReference: sVariantReference\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t},\n\t\"sap.m.IconTabBar\": {\n\t\tretrieve: function(oTabBar: any) {\n\t\t\treturn {\n\t\t\t\tselectedKey: oTabBar.getSelectedKey()\n\t\t\t};\n\t\t},\n\t\tapply: function(oTabBar: any, oControlState: any) {\n\t\t\tif (oControlState && oControlState.selectedKey) {\n\t\t\t\tconst oSelectedItem = oTabBar.getItems().find(function(oItem: any) {\n\t\t\t\t\treturn oItem.getKey() === oControlState.selectedKey;\n\t\t\t\t});\n\t\t\t\tif (oSelectedItem) {\n\t\t\t\t\toTabBar.setSelectedItem(oSelectedItem);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t},\n\t\"sap.ui.mdc.FilterBar\": {\n\t\tretrieve: function(oFilterBar: any) {\n\t\t\treturn StateUtil.retrieveExternalState(oFilterBar).then(function(mFilterBarState: any) {\n\t\t\t\t// remove sensitive or view state irrelevant fields\n\t\t\t\tconst aPropertiesInfo = oFilterBar.getPropertyInfoSet(),\n\t\t\t\t\tmFilter = mFilterBarState.filter || {};\n\t\t\t\taPropertiesInfo\n\t\t\t\t\t.filter(function(oPropertyInfo: any) {\n\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\tmFilter[oPropertyInfo.path] && (oPropertyInfo.removeFromAppState || mFilter[oPropertyInfo.path].length === 0)\n\t\t\t\t\t\t);\n\t\t\t\t\t})\n\t\t\t\t\t.forEach(function(oPropertyInfo: any) {\n\t\t\t\t\t\tdelete mFilter[oPropertyInfo.path];\n\t\t\t\t\t});\n\t\t\t\treturn mFilterBarState;\n\t\t\t});\n\t\t},\n\t\tapply: function(oFilterBar: any, oControlState: any) {\n\t\t\tif (oControlState) {\n\t\t\t\treturn StateUtil.applyExternalState(oFilterBar, oControlState);\n\t\t\t}\n\t\t}\n\t},\n\t\"sap.ui.mdc.Table\": {\n\t\tretrieve: function(oTable: any) {\n\t\t\treturn StateUtil.retrieveExternalState(oTable);\n\t\t},\n\t\tapply: function(oTable: any, oControlState: any) {\n\t\t\tif (oControlState) {\n\t\t\t\treturn StateUtil.applyExternalState(oTable, oControlState);\n\t\t\t}\n\t\t},\n\t\trefreshBinding: function(oTable: any) {\n\t\t\tconst oTableBinding = oTable.getRowBinding();\n\t\t\tif (oTableBinding) {\n\t\t\t\tconst oRootBinding = oTableBinding.getRootBinding();\n\t\t\t\tif (oRootBinding === oTableBinding) {\n\t\t\t\t\t// absolute binding\n\t\t\t\t\toTableBinding.refresh();\n\t\t\t\t} else {\n\t\t\t\t\t// relative binding\n\t\t\t\t\tconst oHeaderContext = oTableBinding.getHeaderContext();\n\t\t\t\t\tconst sGroupId = oTableBinding.getGroupId();\n\n\t\t\t\t\tif (oHeaderContext) {\n\t\t\t\t\t\toHeaderContext.requestSideEffects([{ $NavigationPropertyPath: \"\" }], sGroupId);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tLog.info(\"Table: \" + oTable.getId() + \" was not refreshed. No binding found!\");\n\t\t\t}\n\t\t}\n\t},\n\t\"sap.uxap.ObjectPageLayout\": {\n\t\tretrieve: function(oOPLayout: any) {\n\t\t\treturn {\n\t\t\t\tselectedSection: oOPLayout.getSelectedSection()\n\t\t\t};\n\t\t},\n\t\tapply: function(oOPLayout: any, oControlState: any) {\n\t\t\toControlState && oOPLayout.setSelectedSection(oControlState.selectedSection);\n\t\t},\n\t\trefreshBinding: function(oOPLayout: any) {\n\t\t\tconst oBindingContext = oOPLayout.getBindingContext();\n\t\t\tconst oBinding = oBindingContext && oBindingContext.getBinding();\n\t\t\tif (oBinding) {\n\t\t\t\tconst sMetaPath = ModelHelper.getMetaPathForContext(oBindingContext);\n\t\t\t\tconst sStrategy = KeepAliveHelper.getControlRefreshStrategyForContextPath(oOPLayout, sMetaPath);\n\t\t\t\tif (sStrategy === \"self\") {\n\t\t\t\t\t// Refresh main context and 1-1 navigation properties or OP\n\t\t\t\t\tconst oModel = oBindingContext.getModel(),\n\t\t\t\t\t\toMetaModel = oModel.getMetaModel(),\n\t\t\t\t\t\toNavigationProperties =\n\t\t\t\t\t\t\tCommonUtils.getContextPathProperties(oMetaModel, sMetaPath, {\n\t\t\t\t\t\t\t\t$kind: \"NavigationProperty\"\n\t\t\t\t\t\t\t}) || {},\n\t\t\t\t\t\taNavPropertiesToRequest = Object.keys(oNavigationProperties).reduce(function(aPrev: any[], sNavProp: string) {\n\t\t\t\t\t\t\tif (oNavigationProperties[sNavProp].$isCollection !== true) {\n\t\t\t\t\t\t\t\taPrev.push({ $NavigationPropertyPath: sNavProp });\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\treturn aPrev;\n\t\t\t\t\t\t}, []),\n\t\t\t\t\t\taProperties = [{ $PropertyPath: \"*\" }],\n\t\t\t\t\t\tsGroupId = oBinding.getGroupId();\n\n\t\t\t\t\toBindingContext.requestSideEffects(aProperties.concat(aNavPropertiesToRequest), sGroupId);\n\t\t\t\t} else if (sStrategy === \"includingDependents\") {\n\t\t\t\t\t// Complete refresh\n\t\t\t\t\toBinding.refresh();\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tLog.info(\"ObjectPage: \" + oOPLayout.getId() + \" was not refreshed. No binding found!\");\n\t\t\t}\n\t\t}\n\t},\n\t\"sap.fe.macros.table.QuickFilterContainer\": {\n\t\tretrieve: function(oQuickFilter: any) {\n\t\t\treturn {\n\t\t\t\tselectedKey: oQuickFilter.getSelectorKey()\n\t\t\t};\n\t\t},\n\t\tapply: function(oQuickFilter: any, oControlState: any) {\n\t\t\toControlState && oQuickFilter.setSelectorKey(oControlState.selectedKey);\n\t\t}\n\t},\n\t\"sap.m.SegmentedButton\": {\n\t\tretrieve: function(oSegmentedButton: any) {\n\t\t\treturn {\n\t\t\t\tselectedKey: oSegmentedButton.getSelectedKey()\n\t\t\t};\n\t\t},\n\t\tapply: function(oSegmentedButton: any, oControlState: any) {\n\t\t\toControlState && oSegmentedButton.setSelectedKey(oControlState.selectedKey);\n\t\t}\n\t},\n\t\"sap.m.Select\": {\n\t\tretrieve: function(oSelect: any) {\n\t\t\treturn {\n\t\t\t\tselectedKey: oSelect.getSelectedKey()\n\t\t\t};\n\t\t},\n\t\tapply: function(oSelect: any, oControlState: any) {\n\t\t\toControlState && oSelect.setSelectedKey(oControlState.selectedKey);\n\t\t}\n\t},\n\t\"sap.f.DynamicPage\": {\n\t\tretrieve: function(oDynamicPage: any) {\n\t\t\treturn {\n\t\t\t\theaderExpanded: oDynamicPage.getHeaderExpanded()\n\t\t\t};\n\t\t},\n\t\tapply: function(oDynamicPage: any, oControlState: any) {\n\t\t\toControlState && oDynamicPage.setHeaderExpanded(oControlState.headerExpanded);\n\t\t}\n\t},\n\t\"sap.ui.core.mvc.View\": {\n\t\tretrieve: function(oView: any) {\n\t\t\tconst oController = oView.getController();\n\t\t\tif (oController && oController.viewState) {\n\t\t\t\treturn oController.viewState.retrieveViewState(oController.viewState);\n\t\t\t}\n\t\t\treturn {};\n\t\t},\n\t\tapply: function(oView: any, oControlState: any, oNavParameters: any) {\n\t\t\tconst oController = oView.getController();\n\t\t\tif (oController && oController.viewState) {\n\t\t\t\treturn oController.viewState.applyViewState(oControlState, oNavParameters);\n\t\t\t}\n\t\t},\n\t\trefreshBinding: function(oView: any) {\n\t\t\tconst oController = oView.getController();\n\t\t\tif (oController && oController.viewState) {\n\t\t\t\treturn oController.viewState.refreshViewBindings();\n\t\t\t}\n\t\t}\n\t},\n\t\"sap.ui.core.ComponentContainer\": {\n\t\tretrieve: function(oComponentContainer: any) {\n\t\t\tconst oComponent = oComponentContainer.getComponentInstance();\n\t\t\tif (oComponent) {\n\t\t\t\treturn this.retrieveControlState(oComponent.getRootControl());\n\t\t\t}\n\t\t\treturn {};\n\t\t},\n\t\tapply: function(oComponentContainer: any, oControlState: any, oNavParameters: any) {\n\t\t\tconst oComponent = oComponentContainer.getComponentInstance();\n\t\t\tif (oComponent) {\n\t\t\t\treturn this.applyControlState(oComponent.getRootControl(), oControlState, oNavParameters);\n\t\t\t}\n\t\t}\n\t}\n};\n/**\n * A controller extension offering hooks for state handling\n *\n * If you need to maintain a specific state for your application, you can use the controller extension.\n *\n * @hideconstructor\n * @public\n * @since 1.85.0\n */\n@UI5Class(\"sap.fe.core.controllerextensions.ViewState\", ControllerExtensionMetadata)\nclass ViewState extends ControllerExtension {\n\tprivate _iRetrievingStateCounter: number;\n\tprivate _pInitialStateApplied: Promise<unknown>;\n\tprivate _pInitialStateAppliedResolve?: Function;\n\tprivate base!: PageController;\n\n\t/**\n\t * Constructor.\n\t */\n\tconstructor() {\n\t\tsuper();\n\t\tthis._iRetrievingStateCounter = 0;\n\t\tthis._pInitialStateApplied = new Promise(resolve => {\n\t\t\tthis._pInitialStateAppliedResolve = resolve;\n\t\t});\n\t}\n\n\t/**\n\t * @private\n\t * @name sap.fe.core.controllerextensions.ViewState.getMetadata\n\t * @function\n\t */\n\t/**\n\t * @private\n\t * @name sap.fe.core.controllerextensions.ViewState.extend\n\t * @function\n\t */\n\n\t@Public\n\t@Final\n\trefreshViewBindings() {\n\t\treturn this.collectResults(this.base.viewState.adaptBindingRefreshControls).then((aControls: any) => {\n\t\t\tlet oPromiseChain = Promise.resolve();\n\t\t\taControls\n\t\t\t\t.filter((oControl: any) => {\n\t\t\t\t\treturn oControl && oControl.isA && oControl.isA(\"sap.ui.base.ManagedObject\");\n\t\t\t\t})\n\t\t\t\t.forEach((oControl: any) => {\n\t\t\t\t\toPromiseChain = oPromiseChain.then(this.refreshControlBinding.bind(this, oControl));\n\t\t\t\t});\n\t\t\treturn oPromiseChain;\n\t\t});\n\t}\n\t/**\n\t * This function should add all controls relevant for refreshing to the provided control array.\n\t *\n\t * This function is meant to be individually overridden by consuming controllers, but not to be called directly.\n\t * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.\n\t * @param {Array<sap.ui.base.ManagedObject>} aCollectedControls The collected controls\n\t * @alias sap.fe.core.controllerextensions.ViewState#adaptBindingRefreshControls\n\t * @protected\n\t */\n\t@Public\n\t@Extensible(OverrideExecution.After)\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tadaptBindingRefreshControls(aCollectedControls: ManagedObject[]) {\n\t\t// to be overriden\n\t}\n\n\t@Private\n\t@Final\n\trefreshControlBinding(oControl: any) {\n\t\tconst oControlRefreshBindingHandler = this.getControlRefreshBindingHandler(oControl);\n\t\tlet oPromiseChain = Promise.resolve();\n\t\tif (typeof oControlRefreshBindingHandler.refreshBinding !== \"function\") {\n\t\t\tLog.info(\"refreshBinding handler for control: \" + oControl.getMetadata().getName() + \" is not provided\");\n\t\t} else {\n\t\t\toPromiseChain = oPromiseChain.then(oControlRefreshBindingHandler.refreshBinding.bind(this, oControl));\n\t\t}\n\t\treturn oPromiseChain;\n\t}\n\n\t/**\n\t * Returns a map of <code>refreshBinding</code> function for a certain control.\n\t *\n\t * @param {sap.ui.base.ManagedObject} oControl The control to get state handler for\n\t * @returns {object} A plain object with one function: <code>refreshBinding</code>\n\t */\n\n\t@Private\n\t@Final\n\tgetControlRefreshBindingHandler(oControl: any): any {\n\t\tconst oRefreshBindingHandler: any = {};\n\t\tif (oControl) {\n\t\t\tfor (const sType in _mControlStateHandlerMap) {\n\t\t\t\tif (oControl.isA(sType)) {\n\t\t\t\t\t// pass only the refreshBinding handler in an object so that :\n\t\t\t\t\t// 1. Application has access only to refreshBinding and not apply and reterive at this stage\n\t\t\t\t\t// 2. Application modifications to the object will be reflected here (as we pass by reference)\n\t\t\t\t\toRefreshBindingHandler[\"refreshBinding\"] = _mControlStateHandlerMap[sType].refreshBinding || {};\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tthis.base.viewState.adaptBindingRefreshHandler(oControl, oRefreshBindingHandler);\n\t\treturn oRefreshBindingHandler;\n\t}\n\t/**\n\t * Customize the <code>refreshBinding</code> function for a certain control.\n\t *\n\t * This function is meant to be individually overridden by consuming controllers, but not to be called directly.\n\t * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.\n\t *\n\t * @param {sap.ui.base.ManagedObject} oControl The control for which the refresh handler is adapted.\n\t * @param {Array<object>} oControlHandler A plain object which can have one function: <code>refreshBinding</code>\n\t *\n\t * @alias sap.fe.core.controllerextensions.ViewState#adaptBindingRefreshHandler\n\t * @protected\n\t */\n\t@Public\n\t@Extensible(OverrideExecution.After)\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tadaptBindingRefreshHandler(oControl: ManagedObject, oControlHandler: any[]) {\n\t\t// to be overriden\n\t}\n\n\t/**\n\t * Called when the application is suspended due to keep-alive mode.\n\t *\n\t * @alias sap.fe.core.controllerextensions.ViewState#onSuspend\n\t * @public\n\t */\n\t@Public\n\t@Extensible(OverrideExecution.After)\n\tonSuspend() {\n\t\t// to be overriden\n\t}\n\n\t/**\n\t * Called when the application is restored due to keep-alive mode.\n\t *\n\t * @alias sap.fe.core.controllerextensions.ViewState#onRestore\n\t * @public\n\t */\n\t@Public\n\t@Extensible(OverrideExecution.After)\n\tonRestore() {\n\t\t// to be overriden\n\t}\n\n\t/**\n\t * Destructor method for objects.\n\t */\n\tdestroy() {\n\t\tdelete this._pInitialStateAppliedResolve;\n\t\tsuper.destroy();\n\t}\n\n\t/**\n\t * Helper function to enable multi override. It is adding an additional parameter (array) to the provided\n\t * function (and its parameters), that will be evaluated via <code>Promise.all</code>.\n\t *\n\t * @param {Function} fnCall The function to be called\n\t * @param args\n\t * @returns {Promise} A promise to be resolved with the result of all overrides\n\t */\n\t@Private\n\t@Final\n\tcollectResults(fnCall: Function, ...args: any[]) {\n\t\tconst aResults: any[] = [];\n\t\targs.push(aResults);\n\t\tfnCall.apply(this, args);\n\t\treturn Promise.all(aResults);\n\t}\n\n\t/**\n\t * Customize the <code>retrieve</code> and <code>apply</code> functions for a certain control.\n\t *\n\t * This function is meant to be individually overridden by consuming controllers, but not to be called directly.\n\t * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.\n\t *\n\t * @param {sap.ui.base.ManagedObject} oControl The control to get state handler for\n\t * @param {Array<object>} aControlHandler A list of plain objects with two functions: <code>retrieve</code> and <code>apply</code>\n\t *\n\t * @alias sap.fe.core.controllerextensions.ViewState#adaptControlStateHandler\n\t * @protected\n\t */\n\t@Public\n\t@Extensible(OverrideExecution.After)\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tadaptControlStateHandler(oControl: ManagedObject, aControlHandler: object[]) {\n\t\t// to be overridden if needed\n\t}\n\n\t/**\n\t * Returns a map of <code>retrieve</code> and <code>apply</code> functions for a certain control.\n\t *\n\t * @param {sap.ui.base.ManagedObject} oControl The control to get state handler for\n\t * @returns {object} A plain object with two functions: <code>retrieve</code> and <code>apply</code>\n\t */\n\t@Private\n\t@Final\n\tgetControlStateHandler(oControl: any) {\n\t\tconst aInternalControlStateHandler = [],\n\t\t\taCustomControlStateHandler: any[] = [];\n\t\tif (oControl) {\n\t\t\tfor (const sType in _mControlStateHandlerMap) {\n\t\t\t\tif (oControl.isA(sType)) {\n\t\t\t\t\t// avoid direct manipulation of internal _mControlStateHandlerMap\n\t\t\t\t\taInternalControlStateHandler.push(Object.assign({}, _mControlStateHandlerMap[sType]));\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tthis.base.viewState.adaptControlStateHandler(oControl, aCustomControlStateHandler);\n\t\treturn aInternalControlStateHandler.concat(aCustomControlStateHandler);\n\t}\n\n\t/**\n\t * This function should add all controls for given view that should be considered for the state handling to the provided control array.\n\t *\n\t * This function is meant to be individually overridden by consuming controllers, but not to be called directly.\n\t * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.\n\t * @param {Array<sap.ui.base.ManagedObject>} aCollectedControls The collected controls\n\t * @alias sap.fe.core.controllerextensions.ViewState#adaptStateControls\n\t * @protected\n\t */\n\t@Public\n\t@Extensible(OverrideExecution.After)\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tadaptStateControls(aCollectedControls: ManagedObject[]) {\n\t\t// to be overridden if needed\n\t}\n\n\t/**\n\t * Returns the key to be used for given control.\n\t *\n\t * @param {sap.ui.base.ManagedObject} oControl The control to get state key for\n\t * @returns {string} The key to be used for storing the controls state\n\t */\n\t@Public\n\t@Final\n\tgetStateKey(oControl: any) {\n\t\treturn this.getView().getLocalId(oControl.getId()) || oControl.getId();\n\t}\n\n\t/**\n\t * Retrieve the view state of this extensions view.\n\t * When this function is called more than once before finishing, all but the final response will resolve to <code>undefined</code>.\n\t *\n\t * @returns {Promise} A promise resolving the view state\n\t *\n\t * @alias sap.fe.core.controllerextensions.ViewState#retrieveViewState\n\t * @public\n\t */\n\t@Public\n\t@Final\n\tretrieveViewState() {\n\t\t++this._iRetrievingStateCounter;\n\t\treturn this._pInitialStateApplied\n\t\t\t.then(() => {\n\t\t\t\treturn this.collectResults(this.base.viewState.adaptStateControls);\n\t\t\t})\n\t\t\t.then((aControls: any) => {\n\t\t\t\treturn Promise.all(\n\t\t\t\t\taControls\n\t\t\t\t\t\t.filter(function(oControl: any) {\n\t\t\t\t\t\t\treturn oControl && oControl.isA && oControl.isA(\"sap.ui.base.ManagedObject\");\n\t\t\t\t\t\t})\n\t\t\t\t\t\t.map((oControl: any) => {\n\t\t\t\t\t\t\treturn this.retrieveControlState(oControl).then((vResult: any) => {\n\t\t\t\t\t\t\t\treturn {\n\t\t\t\t\t\t\t\t\tkey: this.getStateKey(oControl),\n\t\t\t\t\t\t\t\t\tvalue: vResult\n\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t})\n\t\t\t\t);\n\t\t\t})\n\t\t\t.then(function(aResolvedStates: any) {\n\t\t\t\treturn aResolvedStates.reduce(function(oStates: any, mState: any) {\n\t\t\t\t\tconst oCurrentState: any = {};\n\t\t\t\t\toCurrentState[mState.key] = mState.value;\n\t\t\t\t\treturn mergeObjects(oStates, oCurrentState);\n\t\t\t\t}, {});\n\t\t\t})\n\t\t\t.then((oViewState: any) => {\n\t\t\t\treturn Promise.resolve(this._retrieveAdditionalStates()).then(function(mAdditionalStates: any) {\n\t\t\t\t\tif (mAdditionalStates && Object.keys(mAdditionalStates).length) {\n\t\t\t\t\t\toViewState[ADDITIONAL_STATES_KEY] = mAdditionalStates;\n\t\t\t\t\t}\n\t\t\t\t\treturn oViewState;\n\t\t\t\t});\n\t\t\t})\n\t\t\t.finally(() => {\n\t\t\t\t--this._iRetrievingStateCounter;\n\t\t\t})\n\t\t\t.then((oViewState: any) => {\n\t\t\t\treturn this._iRetrievingStateCounter === 0 ? oViewState : undefined;\n\t\t\t});\n\t}\n\n\t/**\n\t * Extend the map of additional states (not control bound) to be added to the current view state of the given view.\n\t *\n\t * This function is meant to be individually overridden by consuming controllers, but not to be called directly.\n\t * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.\n\t *\n\t * @param {object} mAdditionalStates The additional state\n\t *\n\t * @alias sap.fe.core.controllerextensions.ViewState#retrieveAdditionalStates\n\t * @protected\n\t */\n\t@Public\n\t@Extensible(OverrideExecution.After)\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tretrieveAdditionalStates(mAdditionalStates: object) {\n\t\t// to be overridden if needed\n\t}\n\n\t/**\n\t * Returns a map of additional states (not control bound) to be added to the current view state of the given view.\n\t *\n\t * @returns {object | Promise<object>} Additional view states\n\t */\n\t_retrieveAdditionalStates() {\n\t\tconst mAdditionalStates = {};\n\t\tthis.base.viewState.retrieveAdditionalStates(mAdditionalStates);\n\t\treturn mAdditionalStates;\n\t}\n\n\t/**\n\t * Returns the current state for the given control.\n\t *\n\t * @param {sap.ui.base.ManagedObject} oControl The object to get the state for\n\t * @returns {Promise<object>} The state for the given control\n\t */\n\t@Private\n\t@Final\n\tretrieveControlState(oControl: any) {\n\t\tconst aControlStateHandlers = this.getControlStateHandler(oControl);\n\t\treturn Promise.all(\n\t\t\taControlStateHandlers.map((mControlStateHandler: any) => {\n\t\t\t\tif (typeof mControlStateHandler.retrieve !== \"function\") {\n\t\t\t\t\tthrow new Error(\"controlStateHandler.retrieve is not a function for control: \" + oControl.getMetadata().getName());\n\t\t\t\t}\n\t\t\t\treturn mControlStateHandler.retrieve.call(this, oControl);\n\t\t\t})\n\t\t).then((aStates: any[]) => {\n\t\t\treturn aStates.reduce(function(oFinalState: any, oCurrentState: any) {\n\t\t\t\treturn mergeObjects(oFinalState, oCurrentState);\n\t\t\t}, {});\n\t\t});\n\t}\n\n\t/**\n\t * Defines whether the view state should only be applied once initially.\n\t *\n\t * This function is meant to be individually overridden by consuming controllers, but not to be called directly.\n\t * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.Instead}.\n\t *\n\t * Important:\n\t * You should only override this method for custom pages and not for the standard ListReportPage and ObjectPage!\n\t *\n\t * @returns {boolean} If <code>true</code>, only the initial view state is applied once,\n\t * else any new view state is also applied on follow-up calls (default)\n\t *\n\t * @alias sap.fe.core.controllerextensions.ViewState#applyInitialStateOnly\n\t * @protected\n\t */\n\t@Public\n\t@Extensible(OverrideExecution.Instead)\n\tapplyInitialStateOnly() {\n\t\treturn true;\n\t}\n\t/**\n\t * Applies the given view state to this extensions view.\n\t *\n\t * @param {object} oViewState The view state to apply (can be undefined)\n\t * @param {object} oNavParameter The current navigation parameter\n\t * @param {sap.fe.navigation.NavType} oNavParameter.navigationType The actual navigation type\n\t * @param {object} oNavParameter.selectionVariant The selectionVariant from the navigation\n\t * @param {object} oNavParameter.selectionVariantDefaults The selectionVariant defaults from the navigation\n\t * @param {boolean} oNavParameter.requiresStandardVariant Defines whether standard variant must be used in VM\n\t *\n\t * @returns {Promise} Promise for async state handling\n\t *\n\t * @alias sap.fe.core.controllerextensions.ViewState#applyViewState\n\t * @public\n\t */\n\t@Public\n\t@Final\n\tapplyViewState(\n\t\toViewState: any,\n\t\toNavParameter: {\n\t\t\tnavigationType: any;\n\t\t\tselectionVariant?: object;\n\t\t\tselectionVariantDefaults?: object;\n\t\t\trequiresStandardVariant?: boolean;\n\t\t}\n\t): Promise<any> {\n\t\tif (this.base.viewState.applyInitialStateOnly() && this._getInitialStateApplied()) {\n\t\t\treturn Promise.resolve();\n\t\t}\n\t\treturn this.collectResults(this.base.viewState.onBeforeStateApplied)\n\t\t\t.then(() => {\n\t\t\t\treturn this.collectResults(this.base.viewState.adaptStateControls);\n\t\t\t})\n\t\t\t.then((aControls: any) => {\n\t\t\t\tlet oPromiseChain = Promise.resolve();\n\t\t\t\taControls\n\t\t\t\t\t.filter(function(oControl: any) {\n\t\t\t\t\t\treturn oControl && oControl.isA && oControl.isA(\"sap.ui.base.ManagedObject\");\n\t\t\t\t\t})\n\t\t\t\t\t.forEach((oControl: any) => {\n\t\t\t\t\t\tconst sKey = this.getStateKey(oControl);\n\t\t\t\t\t\toPromiseChain = oPromiseChain.then(\n\t\t\t\t\t\t\tthis.applyControlState.bind(this, oControl, oViewState ? oViewState[sKey] : undefined, oNavParameter)\n\t\t\t\t\t\t);\n\t\t\t\t\t});\n\t\t\t\treturn oPromiseChain;\n\t\t\t})\n\t\t\t.then(() => {\n\t\t\t\tif (oNavParameter.navigationType === NavType.iAppState) {\n\t\t\t\t\treturn this.collectResults(\n\t\t\t\t\t\tthis.base.viewState.applyAdditionalStates,\n\t\t\t\t\t\toViewState ? oViewState[ADDITIONAL_STATES_KEY] : undefined\n\t\t\t\t\t);\n\t\t\t\t} else {\n\t\t\t\t\treturn this.collectResults(this.base.viewState.applyNavigationParameters, oNavParameter);\n\t\t\t\t}\n\t\t\t})\n\t\t\t.finally(() => {\n\t\t\t\treturn this.collectResults(this.base.viewState.onAfterStateApplied).then(this._setInitialStateApplied.bind(this));\n\t\t\t});\n\t}\n\n\t@Private\n\t_checkIfVariantIdIsAvailable(oVM: any, sVariantId: any) {\n\t\tconst aVariants = oVM.getVariants();\n\t\tlet bIsControlStateVariantAvailable = false;\n\t\taVariants.forEach(function(oVariant: any) {\n\t\t\tif (oVariant.key === sVariantId) {\n\t\t\t\tbIsControlStateVariantAvailable = true;\n\t\t\t}\n\t\t});\n\t\treturn bIsControlStateVariantAvailable;\n\t}\n\n\t_setInitialStateApplied() {\n\t\tif (this._pInitialStateAppliedResolve) {\n\t\t\tconst pInitialStateAppliedResolve = this._pInitialStateAppliedResolve;\n\t\t\tdelete this._pInitialStateAppliedResolve;\n\t\t\tpInitialStateAppliedResolve();\n\t\t}\n\t}\n\t_getInitialStateApplied() {\n\t\treturn !this._pInitialStateAppliedResolve;\n\t}\n\n\t/**\n\t * Hook to react before a state for given view is applied.\n\t *\n\t * This function is meant to be individually overridden by consuming controllers, but not to be called directly.\n\t * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.\n\t *\n\t * @param {Promise} aPromises Extensible array of promises to be resolved before continuing\n\t *\n\t * @alias sap.fe.core.controllerextensions.ViewState#onBeforeStateApplied\n\t * @protected\n\t */\n\t@Public\n\t@Extensible(OverrideExecution.After)\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tonBeforeStateApplied(aPromises: Promise<any>) {\n\t\t// to be overriden\n\t}\n\n\t/**\n\t * Hook to react when state for given view was applied.\n\t *\n\t * This function is meant to be individually overridden by consuming controllers, but not to be called directly.\n\t * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.\n\t *\n\t * @param {Promise} aPromises Extensible array of promises to be resolved before continuing\n\t *\n\t * @alias sap.fe.core.controllerextensions.ViewState#onAfterStateApplied\n\t * @protected\n\t */\n\t@Public\n\t@Extensible(OverrideExecution.After)\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tonAfterStateApplied(aPromises: Promise<any>) {\n\t\t// to be overriden\n\t}\n\n\t/**\n\t * Applying additional, not control related, states - is called only if navigation type is iAppState.\n\t *\n\t * This function is meant to be individually overridden by consuming controllers, but not to be called directly.\n\t * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.\n\t *\n\t * @param {object} oViewState The current view state\n\t * @param {Promise} aPromises Extensible array of promises to be resolved before continuing\n\t *\n\t * @alias sap.fe.core.controllerextensions.ViewState#applyAdditionalStates\n\t * @protected\n\t */\n\t@Public\n\t@Extensible(OverrideExecution.After)\n\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\tapplyAdditionalStates(oViewState: object, aPromises: Promise<any>) {\n\t\t// to be overridden if needed\n\t}\n\n\t/**\n\t * Apply navigation parameters - is called only if navigation type is not iAppState.\n\t *\n\t * This function is meant to be individually overridden by consuming controllers, but not to be called directly.\n\t * The override execution is: {@link sap.ui.core.mvc.OverrideExecution.After}.\n\t *\n\t * @param {object} oNavParameter The current navigation parameter\n\t * @param {sap.fe.navigation.NavType} oNavParameter.navigationType The actual navigation type\n\t * @param {object} [oNavParameter.selectionVariant] The selectionVariant from the navigation\n\t * @param {object} [oNavParameter.selectionVariantDefaults] The selectionVariant defaults from the navigation\n\t * @param {boolean} [oNavParameter.requiresStandardVariant] Defines whether standard variant must be used in VM\n\t * @param {Promise} aPromises Extensible array of promises to be resolved before continuing\n\t *\n\t * @alias sap.fe.core.controllerextensions.ViewState#applyNavigationParameters\n\t * @protected\n\t */\n\t@Public\n\t@Extensible(OverrideExecution.After)\n\tapplyNavigationParameters(\n\t\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\t\toNavParameter: {\n\t\t\tnavigationType: any;\n\t\t\tselectionVariant?: object | undefined;\n\t\t\tselectionVariantDefaults?: object | undefined;\n\t\t\trequiresStandardVariant?: boolean | undefined;\n\t\t},\n\t\t// eslint-disable-next-line @typescript-eslint/no-unused-vars\n\t\taPromises: Promise<any>\n\t) {\n\t\t// to be overridden if needed\n\t}\n\n\t/**\n\t * Applying the given state to the given control.\n\t *\n\t * @param {sap.ui.base.ManagedObject} oControl The object to apply the given state\n\t * @param {object} oControlState The state for the given control\n\t * @param {object} [oNavParameters] The current navigation parameters\n\t * @returns {any} Return a promise for async state handling\n\t */\n\t@Private\n\t@Final\n\tapplyControlState(oControl: any, oControlState: object, oNavParameters?: object) {\n\t\tconst aControlStateHandlers = this.getControlStateHandler(oControl);\n\t\tlet oPromiseChain = Promise.resolve();\n\t\taControlStateHandlers.forEach((mControlStateHandler: any) => {\n\t\t\tif (typeof mControlStateHandler.apply !== \"function\") {\n\t\t\t\tthrow new Error(\"controlStateHandler.apply is not a function for control: \" + oControl.getMetadata().getName());\n\t\t\t}\n\t\t\toPromiseChain = oPromiseChain.then(mControlStateHandler.apply.bind(this, oControl, oControlState, oNavParameters));\n\t\t});\n\t\treturn oPromiseChain;\n\t}\n\tgetInterface() {\n\t\treturn this;\n\t}\n}\n\nexport default ViewState;\n"]}