@sapui5/sap.fe.core 1.102.7 → 1.102.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sapui5/sap.fe.core",
3
- "version": "1.102.7",
3
+ "version": "1.102.8",
4
4
  "description": "SAPUI5 Library sap.fe.core",
5
5
  "license": "SEE LICENSE IN LICENSE.txt",
6
6
  "author": "SAP SE (https://www.sap.com)",
@@ -6,7 +6,7 @@
6
6
  <copyright>SAP UI development toolkit for HTML5 (SAPUI5)
7
7
  (c) Copyright 2009-2021 SAP SE. All rights reserved
8
8
  </copyright>
9
- <version>1.102.7</version>
9
+ <version>1.102.8</version>
10
10
 
11
11
  <documentation>UI5 library: sap.fe.core</documentation>
12
12
 
@@ -24,23 +24,37 @@ sap.ui.define(["sap/base/Log", "sap/fe/core/controllerextensions/pageReady/DataQ
24
24
  _inheritsLoose(PageReadyControllerExtension, _ControllerExtension);
25
25
 
26
26
  function PageReadyControllerExtension() {
27
- return _ControllerExtension.apply(this, arguments) || this;
27
+ var _this;
28
+
29
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
30
+ args[_key] = arguments[_key];
31
+ }
32
+
33
+ _this = _ControllerExtension.call.apply(_ControllerExtension, [this].concat(args)) || this;
34
+ _this.pageReadyTimeoutDefault = 7000;
35
+ return _this;
28
36
  }
29
37
 
30
38
  var _proto = PageReadyControllerExtension.prototype;
31
39
 
32
40
  _proto.onInit = function onInit() {
33
- var _this = this;
41
+ var _manifestContent$sap,
42
+ _manifestContent$sap2,
43
+ _this2 = this;
34
44
 
35
45
  this._nbWaits = 0;
36
46
  this._oEventProvider = this._oEventProvider ? this._oEventProvider : new EventProvider();
37
- this._oView = this.base.getView();
47
+ this._oView = this.getView();
38
48
  this._oAppComponent = CommonUtils.getAppComponent(this._oView);
39
49
  this._oPageComponent = Component.getOwnerComponentFor(this._oView);
40
50
 
51
+ var manifestContent = this._oAppComponent.getManifest();
52
+
53
+ this.pageReadyTimeout = (_manifestContent$sap = (_manifestContent$sap2 = manifestContent["sap.ui5"]) === null || _manifestContent$sap2 === void 0 ? void 0 : _manifestContent$sap2.pageReadyTimeout) !== null && _manifestContent$sap !== void 0 ? _manifestContent$sap : this.pageReadyTimeoutDefault;
54
+
41
55
  if (this._oPageComponent && this._oPageComponent.attachContainerDefined) {
42
56
  this._oPageComponent.attachContainerDefined(function (oEvent) {
43
- return _this.registerContainer(oEvent.getParameter("container"));
57
+ return _this2.registerContainer(oEvent.getParameter("container"));
44
58
  });
45
59
  } else {
46
60
  this.registerContainer(this._oView);
@@ -48,7 +62,7 @@ sap.ui.define(["sap/base/Log", "sap/fe/core/controllerextensions/pageReady/DataQ
48
62
 
49
63
  var oRootControlController = this._oAppComponent.getRootControl().getController();
50
64
 
51
- var oPlaceholder = oRootControlController.getPlaceholder && oRootControlController.getPlaceholder();
65
+ var oPlaceholder = (oRootControlController === null || oRootControlController === void 0 ? void 0 : oRootControlController.getPlaceholder) && oRootControlController.getPlaceholder();
52
66
 
53
67
  if (oPlaceholder !== null && oPlaceholder !== void 0 && oPlaceholder.isPlaceholderDebugEnabled()) {
54
68
  this.attachEvent("pageReady", null, function () {
@@ -73,12 +87,12 @@ sap.ui.define(["sap/base/Log", "sap/fe/core/controllerextensions/pageReady/DataQ
73
87
  };
74
88
 
75
89
  _proto.waitFor = function waitFor(oPromise) {
76
- var _this2 = this;
90
+ var _this3 = this;
77
91
 
78
92
  this._nbWaits++;
79
93
  oPromise.finally(function () {
80
94
  setTimeout(function () {
81
- _this2._nbWaits--;
95
+ _this3._nbWaits--;
82
96
  }, 0);
83
97
  }).catch(null);
84
98
  };
@@ -92,7 +106,7 @@ sap.ui.define(["sap/base/Log", "sap/fe/core/controllerextensions/pageReady/DataQ
92
106
  };
93
107
 
94
108
  _proto.registerAggregatedControls = function registerAggregatedControls(mainBindingContext) {
95
- var _this3 = this;
109
+ var _this4 = this;
96
110
 
97
111
  if (mainBindingContext) {
98
112
  var mainObjectBinding = mainBindingContext.getBinding();
@@ -106,31 +120,42 @@ sap.ui.define(["sap/base/Log", "sap/fe/core/controllerextensions/pageReady/DataQ
106
120
 
107
121
  if (oObjectBinding) {
108
122
  // Register on all object binding (mostly used on object pages)
109
- _this3.queryWatcher.registerBinding(oObjectBinding);
123
+ _this4.queryWatcher.registerBinding(oObjectBinding);
110
124
  } else {
111
125
  var aBindingKeys = Object.keys(oElement.mBindingInfos);
112
126
  aBindingKeys.forEach(function (sPropertyName) {
113
127
  var oListBinding = oElement.mBindingInfos[sPropertyName].binding;
114
128
 
115
129
  if (oListBinding && oListBinding.isA("sap.ui.model.odata.v4.ODataListBinding")) {
116
- _this3.queryWatcher.registerBinding(oListBinding);
130
+ _this4.queryWatcher.registerBinding(oListBinding);
117
131
  }
118
132
  });
119
133
  } // This is dirty but MDCTables and MDCCharts have a weird loading lifecycle
120
134
 
121
135
 
122
136
  if (oElement.isA("sap.ui.mdc.Table") || oElement.isA("sap.ui.mdc.Chart")) {
123
- _this3.bTablesChartsLoaded = false;
124
- aPromises.push(_this3.queryWatcher.registerTableOrChart(oElement));
137
+ _this4.bTablesChartsLoaded = false;
138
+ aPromises.push(_this4.queryWatcher.registerTableOrChart(oElement));
125
139
  } else if (oElement.isA("sap.fe.core.controls.FilterBar")) {
126
- _this3.queryWatcher.registerFilterBar(oElement);
140
+ _this4.queryWatcher.registerFilterBar(oElement);
127
141
  }
128
142
  });
129
143
  return aPromises;
130
144
  };
131
145
 
132
146
  _proto.onAfterBinding = function onAfterBinding(oBindingContext) {
133
- var _this4 = this;
147
+ var _this5 = this;
148
+
149
+ // In case the page is rebind we need to clear the timer (eg: in FCL, the user can select 2 items successively in the list report)
150
+ if (this.pageReadyTimeoutTimer) {
151
+ clearTimeout(this.pageReadyTimeoutTimer);
152
+ }
153
+
154
+ this.pageReadyTimeoutTimer = setTimeout(function () {
155
+ Log.error("The PageReady Event was not fired within the ".concat(_this5.pageReadyTimeout, " ms timeout . It has been forced."));
156
+
157
+ _this5._oEventProvider.fireEvent("pageReady");
158
+ }, this.pageReadyTimeout);
134
159
 
135
160
  if (this._bAfterBindingAlreadyApplied) {
136
161
  return;
@@ -147,17 +172,19 @@ sap.ui.define(["sap/base/Log", "sap/fe/core/controllerextensions/pageReady/DataQ
147
172
  }
148
173
 
149
174
  this.attachEventOnce("pageReady", null, function () {
150
- _this4._bAfterBindingAlreadyApplied = false;
175
+ clearTimeout(_this5.pageReadyTimeoutTimer);
176
+ _this5.pageReadyTimeoutTimer = undefined;
177
+ _this5._bAfterBindingAlreadyApplied = false;
151
178
 
152
- _this4.queryWatcher.reset();
179
+ _this5.queryWatcher.reset();
153
180
  }, null);
154
181
  var aTableChartInitializedPromises = this.registerAggregatedControls(oBindingContext);
155
182
 
156
183
  if (aTableChartInitializedPromises.length > 0) {
157
184
  Promise.all(aTableChartInitializedPromises).finally(function () {
158
- _this4.bTablesChartsLoaded = true;
185
+ _this5.bTablesChartsLoaded = true;
159
186
 
160
- _this4.checkPageReadyDebounced();
187
+ _this5.checkPageReadyDebounced();
161
188
  }).catch(function (oError) {
162
189
  Log.info("There was an error with one or multiple tables or charts", oError);
163
190
  });
@@ -169,15 +196,15 @@ sap.ui.define(["sap/base/Log", "sap/fe/core/controllerextensions/pageReady/DataQ
169
196
  };
170
197
 
171
198
  _proto.waitPageReady = function waitPageReady() {
172
- var _this5 = this;
199
+ var _this6 = this;
173
200
 
174
201
  return new Promise(function (resolve) {
175
- if (_this5.isPageReady()) {
202
+ if (_this6.isPageReady()) {
176
203
  resolve();
177
204
  } else {
178
- _this5.attachEventOnce("pageReady", null, function () {
205
+ _this6.attachEventOnce("pageReady", null, function () {
179
206
  resolve();
180
- }, _this5);
207
+ }, _this6);
181
208
  }
182
209
  });
183
210
  };
@@ -198,22 +225,22 @@ sap.ui.define(["sap/base/Log", "sap/fe/core/controllerextensions/pageReady/DataQ
198
225
  };
199
226
 
200
227
  _proto.registerContainer = function registerContainer(oContainer) {
201
- var _this6 = this;
228
+ var _this7 = this;
202
229
 
203
230
  this._oContainer = oContainer;
204
231
  this._fnContainerDelegate = {
205
232
  onBeforeShow: function () {
206
- _this6.bShown = false;
207
- _this6._bIsPageReady = false;
233
+ _this7.bShown = false;
234
+ _this7._bIsPageReady = false;
208
235
  },
209
236
  onBeforeHide: function () {
210
- _this6.bShown = false;
211
- _this6._bIsPageReady = false;
237
+ _this7.bShown = false;
238
+ _this7._bIsPageReady = false;
212
239
  },
213
240
  onAfterShow: function () {
214
- _this6.bShown = true;
241
+ _this7.bShown = true;
215
242
 
216
- _this6._checkPageReady(true);
243
+ _this7._checkPageReady(true);
217
244
  }
218
245
  };
219
246
 
@@ -225,19 +252,19 @@ sap.ui.define(["sap/base/Log", "sap/fe/core/controllerextensions/pageReady/DataQ
225
252
  };
226
253
 
227
254
  _proto.checkPageReadyDebounced = function checkPageReadyDebounced() {
228
- var _this7 = this;
255
+ var _this8 = this;
229
256
 
230
257
  if (this.pageReadyTimer) {
231
258
  clearTimeout(this.pageReadyTimer);
232
259
  }
233
260
 
234
261
  this.pageReadyTimer = setTimeout(function () {
235
- _this7._checkPageReady();
262
+ _this8._checkPageReady();
236
263
  }, 200);
237
264
  };
238
265
 
239
266
  _proto._checkPageReady = function _checkPageReady() {
240
- var _this8 = this;
267
+ var _this9 = this;
241
268
 
242
269
  var bFromNav = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
243
270
 
@@ -245,9 +272,9 @@ sap.ui.define(["sap/base/Log", "sap/fe/core/controllerextensions/pageReady/DataQ
245
272
  // Wait until the UI is no longer dirty
246
273
  if (!Core.getUIDirty()) {
247
274
  Core.detachEvent("UIUpdated", fnUIUpdated);
248
- _this8._bWaitingForRefresh = false;
275
+ _this9._bWaitingForRefresh = false;
249
276
  setTimeout(function () {
250
- _this8._checkPageReady();
277
+ _this9._checkPageReady();
251
278
  }, 20);
252
279
  }
253
280
  }; // In case UIUpdate does not get called, check if UI is not dirty and then call _checkPageReady
@@ -256,11 +283,11 @@ sap.ui.define(["sap/base/Log", "sap/fe/core/controllerextensions/pageReady/DataQ
256
283
  var checkUIUpdated = function () {
257
284
  if (Core.getUIDirty()) {
258
285
  setTimeout(checkUIUpdated, 500);
259
- } else if (_this8._bWaitingForRefresh) {
260
- _this8._bWaitingForRefresh = false;
286
+ } else if (_this9._bWaitingForRefresh) {
287
+ _this9._bWaitingForRefresh = false;
261
288
  Core.detachEvent("UIUpdated", fnUIUpdated);
262
289
 
263
- _this8._checkPageReady();
290
+ _this9._checkPageReady();
264
291
  }
265
292
  };
266
293
 
@@ -290,4 +317,4 @@ sap.ui.define(["sap/base/Log", "sap/fe/core/controllerextensions/pageReady/DataQ
290
317
  }(ControllerExtension), (_applyDecoratedDescriptor(_class2.prototype, "onInit", [_dec2], Object.getOwnPropertyDescriptor(_class2.prototype, "onInit"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "onExit", [_dec3], Object.getOwnPropertyDescriptor(_class2.prototype, "onExit"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "waitFor", [_dec4, _dec5], Object.getOwnPropertyDescriptor(_class2.prototype, "waitFor"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "onRouteMatched", [_dec6], Object.getOwnPropertyDescriptor(_class2.prototype, "onRouteMatched"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "onRouteMatchedFinished", [_dec7], Object.getOwnPropertyDescriptor(_class2.prototype, "onRouteMatchedFinished"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "onAfterBinding", [_dec8], Object.getOwnPropertyDescriptor(_class2.prototype, "onAfterBinding"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "isPageReady", [_dec9, _dec10], Object.getOwnPropertyDescriptor(_class2.prototype, "isPageReady"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "waitPageReady", [_dec11, _dec12], Object.getOwnPropertyDescriptor(_class2.prototype, "waitPageReady"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "attachEventOnce", [_dec13, _dec14], Object.getOwnPropertyDescriptor(_class2.prototype, "attachEventOnce"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "attachEvent", [_dec15, _dec16], Object.getOwnPropertyDescriptor(_class2.prototype, "attachEvent"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "detachEvent", [_dec17, _dec18], Object.getOwnPropertyDescriptor(_class2.prototype, "detachEvent"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "isContextExpected", [_dec19, _dec20], Object.getOwnPropertyDescriptor(_class2.prototype, "isContextExpected"), _class2.prototype), _applyDecoratedDescriptor(_class2.prototype, "checkPageReadyDebounced", [_dec21], Object.getOwnPropertyDescriptor(_class2.prototype, "checkPageReadyDebounced"), _class2.prototype)), _class2)) || _class);
291
318
  return PageReadyControllerExtension;
292
319
  }, false);
293
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PageReady.ts"],"names":["PageReadyControllerExtension","defineUI5Class","methodOverride","publicExtension","finalExtension","privateExtension","extensible","OverrideExecution","Instead","onInit","_nbWaits","_oEventProvider","EventProvider","_oView","base","getView","_oAppComponent","CommonUtils","getAppComponent","_oPageComponent","Component","getOwnerComponentFor","attachContainerDefined","oEvent","registerContainer","getParameter","oRootControlController","getRootControl","getController","oPlaceholder","getPlaceholder","isPlaceholderDebugEnabled","attachEvent","getPlaceholderDebugStats","iPageReadyEventTimestamp","Date","now","iHeroesBatchReceivedEventTimestamp","queryWatcher","DataQueryWatcher","checkPageReadyDebounced","bind","onExit","_oContainer","removeEventDelegate","_fnContainerDelegate","waitFor","oPromise","finally","setTimeout","catch","onRouteMatched","_bIsPageReady","onRouteMatchedFinished","registerAggregatedControls","mainBindingContext","mainObjectBinding","getBinding","registerBinding","aPromises","aControls","findAggregatedObjects","forEach","oElement","oObjectBinding","getObjectBinding","aBindingKeys","Object","keys","mBindingInfos","sPropertyName","oListBinding","binding","isA","bTablesChartsLoaded","push","registerTableOrChart","registerFilterBar","onAfterBinding","oBindingContext","_bAfterBindingAlreadyApplied","isContextExpected","undefined","bHasContext","attachEventOnce","reset","aTableChartInitializedPromises","length","Promise","all","oError","Log","info","isPageReady","waitPageReady","resolve","sEventId","oData","fnFunction","oListener","detachEvent","oContainer","onBeforeShow","bShown","onBeforeHide","onAfterShow","_checkPageReady","addEventDelegate","pageReadyTimer","clearTimeout","bFromNav","fnUIUpdated","Core","getUIDirty","_bWaitingForRefresh","checkUIUpdated","isDataReceived","resetDataReceived","TemplatedViewServiceFactory","getNumberOfViewsInCreationState","isSearchPending","fireEvent","ControllerExtension"],"mappings":"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","sourceRoot":".","sourcesContent":["import Log from \"sap/base/Log\";\nimport type AppComponent from \"sap/fe/core/AppComponent\";\nimport DataQueryWatcher from \"sap/fe/core/controllerextensions/pageReady/DataQueryWatcher\";\nimport TemplatedViewServiceFactory from \"sap/fe/core/services/TemplatedViewServiceFactory\";\nimport type Event from \"sap/ui/base/Event\";\nimport EventProvider from \"sap/ui/base/EventProvider\";\nimport type ManagedObject from \"sap/ui/base/ManagedObject\";\nimport Component from \"sap/ui/core/Component\";\nimport Core from \"sap/ui/core/Core\";\nimport ControllerExtension from \"sap/ui/core/mvc/ControllerExtension\";\nimport OverrideExecution from \"sap/ui/core/mvc/OverrideExecution\";\nimport type View from \"sap/ui/core/mvc/View\";\nimport type Context from \"sap/ui/model/odata/v4/Context\";\nimport type { CoreEx } from \"types/extension_types\";\nimport CommonUtils from \"../CommonUtils\";\nimport { defineUI5Class, extensible, finalExtension, methodOverride, privateExtension, publicExtension } from \"../helpers/ClassSupport\";\n@defineUI5Class(\"sap.fe.core.controllerextensions.PageReady\")\nclass PageReadyControllerExtension extends ControllerExtension {\n\tprivate _oEventProvider!: EventProvider;\n\tprivate _oView: any;\n\tprivate _oAppComponent!: AppComponent;\n\tprivate _oPageComponent!: any;\n\tprivate _oContainer!: any;\n\tprivate _bAfterBindingAlreadyApplied!: boolean;\n\tprivate _fnContainerDelegate: any;\n\tprivate _nbWaits!: number;\n\tprivate _bIsPageReady!: boolean;\n\tprivate _bWaitingForRefresh!: boolean;\n\tprivate bShown!: boolean;\n\tprivate bHasContext!: boolean;\n\tprivate bTablesChartsLoaded?: boolean;\n\tprivate pageReadyTimer: NodeJS.Timeout | undefined;\n\tprivate queryWatcher!: DataQueryWatcher;\n\n\t@methodOverride()\n\tpublic onInit() {\n\t\tthis._nbWaits = 0;\n\t\tthis._oEventProvider = this._oEventProvider ? this._oEventProvider : new EventProvider();\n\t\tthis._oView = (this as any).base.getView();\n\t\tthis._oAppComponent = CommonUtils.getAppComponent(this._oView);\n\t\tthis._oPageComponent = Component.getOwnerComponentFor(this._oView);\n\n\t\tif (this._oPageComponent && this._oPageComponent.attachContainerDefined) {\n\t\t\tthis._oPageComponent.attachContainerDefined((oEvent: Event) => this.registerContainer(oEvent.getParameter(\"container\")));\n\t\t} else {\n\t\t\tthis.registerContainer(this._oView);\n\t\t}\n\n\t\tconst oRootControlController = (this._oAppComponent.getRootControl() as View).getController() as any;\n\t\tconst oPlaceholder = oRootControlController.getPlaceholder && oRootControlController.getPlaceholder();\n\t\tif (oPlaceholder?.isPlaceholderDebugEnabled()) {\n\t\t\tthis.attachEvent(\n\t\t\t\t\"pageReady\",\n\t\t\t\tnull,\n\t\t\t\t() => {\n\t\t\t\t\toPlaceholder.getPlaceholderDebugStats().iPageReadyEventTimestamp = Date.now();\n\t\t\t\t},\n\t\t\t\tthis\n\t\t\t);\n\t\t\tthis.attachEvent(\n\t\t\t\t\"heroesBatchReceived\",\n\t\t\t\tnull,\n\t\t\t\t() => {\n\t\t\t\t\toPlaceholder.getPlaceholderDebugStats().iHeroesBatchReceivedEventTimestamp = Date.now();\n\t\t\t\t},\n\t\t\t\tthis\n\t\t\t);\n\t\t}\n\n\t\tthis.queryWatcher = new DataQueryWatcher(this._oEventProvider, this.checkPageReadyDebounced.bind(this));\n\t}\n\n\t@methodOverride()\n\tpublic onExit() {\n\t\t// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n\t\t// @ts-ignore\n\t\tdelete this._oAppComponent;\n\t\tif (this._oContainer) {\n\t\t\tthis._oContainer.removeEventDelegate(this._fnContainerDelegate);\n\t\t}\n\t}\n\n\t@publicExtension()\n\t@finalExtension()\n\tpublic waitFor(oPromise: any) {\n\t\tthis._nbWaits++;\n\t\toPromise\n\t\t\t.finally(() => {\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tthis._nbWaits--;\n\t\t\t\t}, 0);\n\t\t\t})\n\t\t\t.catch(null);\n\t}\n\t@methodOverride(\"_routing\")\n\tonRouteMatched() {\n\t\tthis._bIsPageReady = false;\n\t}\n\t@methodOverride(\"_routing\")\n\tonRouteMatchedFinished() {\n\t\tthis.checkPageReadyDebounced();\n\t}\n\n\tpublic registerAggregatedControls(mainBindingContext?: Context): Promise<void>[] {\n\t\tif (mainBindingContext) {\n\t\t\tconst mainObjectBinding = mainBindingContext.getBinding();\n\t\t\tthis.queryWatcher.registerBinding(mainObjectBinding);\n\t\t}\n\n\t\tconst aPromises: Promise<void>[] = [];\n\t\tconst aControls = this.getView().findAggregatedObjects(true);\n\n\t\taControls.forEach((oElement: any) => {\n\t\t\tconst oObjectBinding = oElement.getObjectBinding();\n\t\t\tif (oObjectBinding) {\n\t\t\t\t// Register on all object binding (mostly used on object pages)\n\t\t\t\tthis.queryWatcher.registerBinding(oObjectBinding);\n\t\t\t} else {\n\t\t\t\tconst aBindingKeys = Object.keys(oElement.mBindingInfos);\n\t\t\t\taBindingKeys.forEach((sPropertyName) => {\n\t\t\t\t\tconst oListBinding = oElement.mBindingInfos[sPropertyName].binding;\n\n\t\t\t\t\tif (oListBinding && oListBinding.isA(\"sap.ui.model.odata.v4.ODataListBinding\")) {\n\t\t\t\t\t\tthis.queryWatcher.registerBinding(oListBinding);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t\t// This is dirty but MDCTables and MDCCharts have a weird loading lifecycle\n\t\t\tif (oElement.isA(\"sap.ui.mdc.Table\") || oElement.isA(\"sap.ui.mdc.Chart\")) {\n\t\t\t\tthis.bTablesChartsLoaded = false;\n\t\t\t\taPromises.push(this.queryWatcher.registerTableOrChart(oElement));\n\t\t\t} else if (oElement.isA(\"sap.fe.core.controls.FilterBar\")) {\n\t\t\t\tthis.queryWatcher.registerFilterBar(oElement);\n\t\t\t}\n\t\t});\n\n\t\treturn aPromises;\n\t}\n\n\t@methodOverride(\"_routing\")\n\tonAfterBinding(oBindingContext: Context) {\n\t\tif (this._bAfterBindingAlreadyApplied) {\n\t\t\treturn;\n\t\t}\n\t\tthis._bAfterBindingAlreadyApplied = true;\n\n\t\tif (this.isContextExpected() && oBindingContext === undefined) {\n\t\t\t// Force to mention we are expecting data\n\t\t\tthis.bHasContext = false;\n\t\t\treturn;\n\t\t} else {\n\t\t\tthis.bHasContext = true;\n\t\t}\n\n\t\tthis.attachEventOnce(\n\t\t\t\"pageReady\",\n\t\t\tnull,\n\t\t\t() => {\n\t\t\t\tthis._bAfterBindingAlreadyApplied = false;\n\t\t\t\tthis.queryWatcher.reset();\n\t\t\t},\n\t\t\tnull\n\t\t);\n\n\t\tconst aTableChartInitializedPromises = this.registerAggregatedControls(oBindingContext);\n\n\t\tif (aTableChartInitializedPromises.length > 0) {\n\t\t\tPromise.all(aTableChartInitializedPromises)\n\t\t\t\t.finally(() => {\n\t\t\t\t\tthis.bTablesChartsLoaded = true;\n\t\t\t\t\tthis.checkPageReadyDebounced();\n\t\t\t\t})\n\t\t\t\t.catch((oError) => {\n\t\t\t\t\tLog.info(\"There was an error with one or multiple tables or charts\", oError);\n\t\t\t\t});\n\t\t}\n\t}\n\n\t@publicExtension()\n\t@finalExtension()\n\tpublic isPageReady() {\n\t\treturn this._bIsPageReady;\n\t}\n\n\t@publicExtension()\n\t@finalExtension()\n\tpublic waitPageReady(): Promise<void> {\n\t\treturn new Promise((resolve) => {\n\t\t\tif (this.isPageReady()) {\n\t\t\t\tresolve();\n\t\t\t} else {\n\t\t\t\tthis.attachEventOnce(\n\t\t\t\t\t\"pageReady\",\n\t\t\t\t\tnull,\n\t\t\t\t\t() => {\n\t\t\t\t\t\tresolve();\n\t\t\t\t\t},\n\t\t\t\t\tthis\n\t\t\t\t);\n\t\t\t}\n\t\t});\n\t}\n\n\t@publicExtension()\n\t@finalExtension()\n\tpublic attachEventOnce(sEventId: string, oData: any, fnFunction?: Function, oListener?: any) {\n\t\t// eslint-disable-next-line prefer-rest-params\n\t\treturn this._oEventProvider.attachEventOnce(sEventId, oData, fnFunction as Function, oListener);\n\t}\n\t@publicExtension()\n\t@finalExtension()\n\tpublic attachEvent(sEventId: string, oData: any, fnFunction: Function, oListener: any) {\n\t\t// eslint-disable-next-line prefer-rest-params\n\t\treturn this._oEventProvider.attachEvent(sEventId, oData, fnFunction, oListener);\n\t}\n\t@publicExtension()\n\t@finalExtension()\n\tpublic detachEvent(sEventId: string, fnFunction: Function) {\n\t\t// eslint-disable-next-line prefer-rest-params\n\t\treturn this._oEventProvider.detachEvent(sEventId, fnFunction);\n\t}\n\tprivate registerContainer(oContainer: ManagedObject) {\n\t\tthis._oContainer = oContainer;\n\t\tthis._fnContainerDelegate = {\n\t\t\tonBeforeShow: () => {\n\t\t\t\tthis.bShown = false;\n\t\t\t\tthis._bIsPageReady = false;\n\t\t\t},\n\t\t\tonBeforeHide: () => {\n\t\t\t\tthis.bShown = false;\n\t\t\t\tthis._bIsPageReady = false;\n\t\t\t},\n\t\t\tonAfterShow: () => {\n\t\t\t\tthis.bShown = true;\n\t\t\t\tthis._checkPageReady(true);\n\t\t\t}\n\t\t};\n\t\tthis._oContainer.addEventDelegate(this._fnContainerDelegate);\n\t}\n\n\t@privateExtension()\n\t@extensible(OverrideExecution.Instead)\n\tpublic isContextExpected() {\n\t\treturn false;\n\t}\n\n\t@publicExtension()\n\tpublic checkPageReadyDebounced() {\n\t\tif (this.pageReadyTimer) {\n\t\t\tclearTimeout(this.pageReadyTimer);\n\t\t}\n\t\tthis.pageReadyTimer = setTimeout(() => {\n\t\t\tthis._checkPageReady();\n\t\t}, 200);\n\t}\n\n\tpublic _checkPageReady(bFromNav: boolean = false) {\n\t\tconst fnUIUpdated = () => {\n\t\t\t// Wait until the UI is no longer dirty\n\t\t\tif (!Core.getUIDirty()) {\n\t\t\t\t(Core as CoreEx).detachEvent(\"UIUpdated\", fnUIUpdated);\n\t\t\t\tthis._bWaitingForRefresh = false;\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tthis._checkPageReady();\n\t\t\t\t}, 20);\n\t\t\t}\n\t\t};\n\n\t\t// In case UIUpdate does not get called, check if UI is not dirty and then call _checkPageReady\n\t\tconst checkUIUpdated = () => {\n\t\t\tif (Core.getUIDirty()) {\n\t\t\t\tsetTimeout(checkUIUpdated, 500);\n\t\t\t} else if (this._bWaitingForRefresh) {\n\t\t\t\tthis._bWaitingForRefresh = false;\n\t\t\t\t(Core as CoreEx).detachEvent(\"UIUpdated\", fnUIUpdated);\n\t\t\t\tthis._checkPageReady();\n\t\t\t}\n\t\t};\n\n\t\tif (\n\t\t\tthis.bShown &&\n\t\t\tthis.queryWatcher.isDataReceived() !== false &&\n\t\t\tthis.bTablesChartsLoaded !== false &&\n\t\t\t(!this.isContextExpected() || this.bHasContext) // Either no context is expected or there is one\n\t\t) {\n\t\t\tif (this.queryWatcher.isDataReceived() === true && !bFromNav && !this._bWaitingForRefresh && Core.getUIDirty()) {\n\t\t\t\t// If we requested data we get notified as soon as the data arrived, so before the next rendering tick\n\t\t\t\tthis.queryWatcher.resetDataReceived();\n\t\t\t\tthis._bWaitingForRefresh = true;\n\t\t\t\t(Core as CoreEx).attachEvent(\"UIUpdated\", fnUIUpdated);\n\t\t\t\tsetTimeout(checkUIUpdated, 500);\n\t\t\t} else if (\n\t\t\t\t(!this._bWaitingForRefresh && Core.getUIDirty()) ||\n\t\t\t\tthis._nbWaits !== 0 ||\n\t\t\t\tTemplatedViewServiceFactory.getNumberOfViewsInCreationState() > 0 ||\n\t\t\t\tthis.queryWatcher.isSearchPending()\n\t\t\t) {\n\t\t\t\tthis._bWaitingForRefresh = true;\n\t\t\t\t(Core as CoreEx).attachEvent(\"UIUpdated\", fnUIUpdated);\n\t\t\t\tsetTimeout(checkUIUpdated, 500);\n\t\t\t} else if (!this._bWaitingForRefresh) {\n\t\t\t\t// In the case we're not waiting for any data (navigating back to a page we already have loaded)\n\t\t\t\t// just wait for a frame to fire the event.\n\t\t\t\tthis._bIsPageReady = true;\n\t\t\t\tthis._oEventProvider.fireEvent(\"pageReady\");\n\t\t\t}\n\t\t}\n\t}\n}\n\nexport default PageReadyControllerExtension;\n"]}
320
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["PageReady.ts"],"names":["PageReadyControllerExtension","defineUI5Class","methodOverride","publicExtension","finalExtension","privateExtension","extensible","OverrideExecution","Instead","pageReadyTimeoutDefault","onInit","_nbWaits","_oEventProvider","EventProvider","_oView","getView","_oAppComponent","CommonUtils","getAppComponent","_oPageComponent","Component","getOwnerComponentFor","manifestContent","getManifest","pageReadyTimeout","attachContainerDefined","oEvent","registerContainer","getParameter","oRootControlController","getRootControl","getController","oPlaceholder","getPlaceholder","isPlaceholderDebugEnabled","attachEvent","getPlaceholderDebugStats","iPageReadyEventTimestamp","Date","now","iHeroesBatchReceivedEventTimestamp","queryWatcher","DataQueryWatcher","checkPageReadyDebounced","bind","onExit","_oContainer","removeEventDelegate","_fnContainerDelegate","waitFor","oPromise","finally","setTimeout","catch","onRouteMatched","_bIsPageReady","onRouteMatchedFinished","registerAggregatedControls","mainBindingContext","mainObjectBinding","getBinding","registerBinding","aPromises","aControls","findAggregatedObjects","forEach","oElement","oObjectBinding","getObjectBinding","aBindingKeys","Object","keys","mBindingInfos","sPropertyName","oListBinding","binding","isA","bTablesChartsLoaded","push","registerTableOrChart","registerFilterBar","onAfterBinding","oBindingContext","pageReadyTimeoutTimer","clearTimeout","Log","error","fireEvent","_bAfterBindingAlreadyApplied","isContextExpected","undefined","bHasContext","attachEventOnce","reset","aTableChartInitializedPromises","length","Promise","all","oError","info","isPageReady","waitPageReady","resolve","sEventId","oData","fnFunction","oListener","detachEvent","oContainer","onBeforeShow","bShown","onBeforeHide","onAfterShow","_checkPageReady","addEventDelegate","pageReadyTimer","bFromNav","fnUIUpdated","Core","getUIDirty","_bWaitingForRefresh","checkUIUpdated","isDataReceived","resetDataReceived","TemplatedViewServiceFactory","getNumberOfViewsInCreationState","isSearchPending","ControllerExtension"],"mappings":"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","sourceRoot":".","sourcesContent":["import Log from \"sap/base/Log\";\nimport type AppComponent from \"sap/fe/core/AppComponent\";\nimport DataQueryWatcher from \"sap/fe/core/controllerextensions/pageReady/DataQueryWatcher\";\nimport TemplatedViewServiceFactory from \"sap/fe/core/services/TemplatedViewServiceFactory\";\nimport type Event from \"sap/ui/base/Event\";\nimport EventProvider from \"sap/ui/base/EventProvider\";\nimport type ManagedObject from \"sap/ui/base/ManagedObject\";\nimport Component from \"sap/ui/core/Component\";\nimport Core from \"sap/ui/core/Core\";\nimport ControllerExtension from \"sap/ui/core/mvc/ControllerExtension\";\nimport OverrideExecution from \"sap/ui/core/mvc/OverrideExecution\";\nimport type View from \"sap/ui/core/mvc/View\";\nimport type Context from \"sap/ui/model/odata/v4/Context\";\nimport type { CoreEx } from \"types/extension_types\";\nimport CommonUtils from \"../CommonUtils\";\nimport { defineUI5Class, extensible, finalExtension, methodOverride, privateExtension, publicExtension } from \"../helpers/ClassSupport\";\n@defineUI5Class(\"sap.fe.core.controllerextensions.PageReady\")\nclass PageReadyControllerExtension extends ControllerExtension {\n\tprivate _oEventProvider!: EventProvider;\n\tprivate _oView: any;\n\tprivate _oAppComponent!: AppComponent;\n\tprivate _oPageComponent!: any;\n\tprivate _oContainer!: any;\n\tprivate _bAfterBindingAlreadyApplied!: boolean;\n\tprivate _fnContainerDelegate: any;\n\tprivate _nbWaits!: number;\n\tprivate _bIsPageReady!: boolean;\n\tprivate _bWaitingForRefresh!: boolean;\n\tprivate bShown!: boolean;\n\tprivate bHasContext!: boolean;\n\tprivate bTablesChartsLoaded?: boolean;\n\tprivate pageReadyTimer: NodeJS.Timeout | undefined;\n\tprivate queryWatcher!: DataQueryWatcher;\n\tprivate pageReadyTimeoutDefault = 7000;\n\tprivate pageReadyTimeoutTimer?: number;\n\tprivate pageReadyTimeout?: number;\n\n\t@methodOverride()\n\tpublic onInit() {\n\t\tthis._nbWaits = 0;\n\t\tthis._oEventProvider = this._oEventProvider ? this._oEventProvider : new EventProvider();\n\t\tthis._oView = this.getView();\n\t\tthis._oAppComponent = CommonUtils.getAppComponent(this._oView);\n\t\tthis._oPageComponent = Component.getOwnerComponentFor(this._oView);\n\n\t\tconst manifestContent = this._oAppComponent.getManifest() as any;\n\t\tthis.pageReadyTimeout = manifestContent[\"sap.ui5\"]?.pageReadyTimeout ?? this.pageReadyTimeoutDefault;\n\n\t\tif (this._oPageComponent && this._oPageComponent.attachContainerDefined) {\n\t\t\tthis._oPageComponent.attachContainerDefined((oEvent: Event) => this.registerContainer(oEvent.getParameter(\"container\")));\n\t\t} else {\n\t\t\tthis.registerContainer(this._oView);\n\t\t}\n\n\t\tconst oRootControlController = (this._oAppComponent.getRootControl() as View).getController() as any;\n\t\tconst oPlaceholder = oRootControlController?.getPlaceholder && oRootControlController.getPlaceholder();\n\t\tif (oPlaceholder?.isPlaceholderDebugEnabled()) {\n\t\t\tthis.attachEvent(\n\t\t\t\t\"pageReady\",\n\t\t\t\tnull,\n\t\t\t\t() => {\n\t\t\t\t\toPlaceholder.getPlaceholderDebugStats().iPageReadyEventTimestamp = Date.now();\n\t\t\t\t},\n\t\t\t\tthis\n\t\t\t);\n\t\t\tthis.attachEvent(\n\t\t\t\t\"heroesBatchReceived\",\n\t\t\t\tnull,\n\t\t\t\t() => {\n\t\t\t\t\toPlaceholder.getPlaceholderDebugStats().iHeroesBatchReceivedEventTimestamp = Date.now();\n\t\t\t\t},\n\t\t\t\tthis\n\t\t\t);\n\t\t}\n\n\t\tthis.queryWatcher = new DataQueryWatcher(this._oEventProvider, this.checkPageReadyDebounced.bind(this));\n\t}\n\n\t@methodOverride()\n\tpublic onExit() {\n\t\t// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n\t\t// @ts-ignore\n\t\tdelete this._oAppComponent;\n\t\tif (this._oContainer) {\n\t\t\tthis._oContainer.removeEventDelegate(this._fnContainerDelegate);\n\t\t}\n\t}\n\n\t@publicExtension()\n\t@finalExtension()\n\tpublic waitFor(oPromise: any) {\n\t\tthis._nbWaits++;\n\t\toPromise\n\t\t\t.finally(() => {\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tthis._nbWaits--;\n\t\t\t\t}, 0);\n\t\t\t})\n\t\t\t.catch(null);\n\t}\n\t@methodOverride(\"_routing\")\n\tonRouteMatched() {\n\t\tthis._bIsPageReady = false;\n\t}\n\t@methodOverride(\"_routing\")\n\tonRouteMatchedFinished() {\n\t\tthis.checkPageReadyDebounced();\n\t}\n\n\tpublic registerAggregatedControls(mainBindingContext?: Context): Promise<void>[] {\n\t\tif (mainBindingContext) {\n\t\t\tconst mainObjectBinding = mainBindingContext.getBinding();\n\t\t\tthis.queryWatcher.registerBinding(mainObjectBinding);\n\t\t}\n\n\t\tconst aPromises: Promise<void>[] = [];\n\t\tconst aControls = this.getView().findAggregatedObjects(true);\n\n\t\taControls.forEach((oElement: any) => {\n\t\t\tconst oObjectBinding = oElement.getObjectBinding();\n\t\t\tif (oObjectBinding) {\n\t\t\t\t// Register on all object binding (mostly used on object pages)\n\t\t\t\tthis.queryWatcher.registerBinding(oObjectBinding);\n\t\t\t} else {\n\t\t\t\tconst aBindingKeys = Object.keys(oElement.mBindingInfos);\n\t\t\t\taBindingKeys.forEach((sPropertyName) => {\n\t\t\t\t\tconst oListBinding = oElement.mBindingInfos[sPropertyName].binding;\n\n\t\t\t\t\tif (oListBinding && oListBinding.isA(\"sap.ui.model.odata.v4.ODataListBinding\")) {\n\t\t\t\t\t\tthis.queryWatcher.registerBinding(oListBinding);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t\t// This is dirty but MDCTables and MDCCharts have a weird loading lifecycle\n\t\t\tif (oElement.isA(\"sap.ui.mdc.Table\") || oElement.isA(\"sap.ui.mdc.Chart\")) {\n\t\t\t\tthis.bTablesChartsLoaded = false;\n\t\t\t\taPromises.push(this.queryWatcher.registerTableOrChart(oElement));\n\t\t\t} else if (oElement.isA(\"sap.fe.core.controls.FilterBar\")) {\n\t\t\t\tthis.queryWatcher.registerFilterBar(oElement);\n\t\t\t}\n\t\t});\n\n\t\treturn aPromises;\n\t}\n\n\t@methodOverride(\"_routing\")\n\tonAfterBinding(oBindingContext?: Context) {\n\t\t// In case the page is rebind we need to clear the timer (eg: in FCL, the user can select 2 items successively in the list report)\n\t\tif (this.pageReadyTimeoutTimer) {\n\t\t\tclearTimeout(this.pageReadyTimeoutTimer);\n\t\t}\n\t\tthis.pageReadyTimeoutTimer = setTimeout(() => {\n\t\t\tLog.error(`The PageReady Event was not fired within the ${this.pageReadyTimeout} ms timeout . It has been forced.`);\n\t\t\tthis._oEventProvider.fireEvent(\"pageReady\");\n\t\t}, this.pageReadyTimeout);\n\n\t\tif (this._bAfterBindingAlreadyApplied) {\n\t\t\treturn;\n\t\t}\n\t\tthis._bAfterBindingAlreadyApplied = true;\n\n\t\tif (this.isContextExpected() && oBindingContext === undefined) {\n\t\t\t// Force to mention we are expecting data\n\t\t\tthis.bHasContext = false;\n\t\t\treturn;\n\t\t} else {\n\t\t\tthis.bHasContext = true;\n\t\t}\n\n\t\tthis.attachEventOnce(\n\t\t\t\"pageReady\",\n\t\t\tnull,\n\t\t\t() => {\n\t\t\t\tclearTimeout(this.pageReadyTimeoutTimer);\n\t\t\t\tthis.pageReadyTimeoutTimer = undefined;\n\t\t\t\tthis._bAfterBindingAlreadyApplied = false;\n\t\t\t\tthis.queryWatcher.reset();\n\t\t\t},\n\t\t\tnull\n\t\t);\n\n\t\tconst aTableChartInitializedPromises = this.registerAggregatedControls(oBindingContext);\n\n\t\tif (aTableChartInitializedPromises.length > 0) {\n\t\t\tPromise.all(aTableChartInitializedPromises)\n\t\t\t\t.finally(() => {\n\t\t\t\t\tthis.bTablesChartsLoaded = true;\n\t\t\t\t\tthis.checkPageReadyDebounced();\n\t\t\t\t})\n\t\t\t\t.catch((oError) => {\n\t\t\t\t\tLog.info(\"There was an error with one or multiple tables or charts\", oError);\n\t\t\t\t});\n\t\t}\n\t}\n\n\t@publicExtension()\n\t@finalExtension()\n\tpublic isPageReady() {\n\t\treturn this._bIsPageReady;\n\t}\n\n\t@publicExtension()\n\t@finalExtension()\n\tpublic waitPageReady(): Promise<void> {\n\t\treturn new Promise((resolve) => {\n\t\t\tif (this.isPageReady()) {\n\t\t\t\tresolve();\n\t\t\t} else {\n\t\t\t\tthis.attachEventOnce(\n\t\t\t\t\t\"pageReady\",\n\t\t\t\t\tnull,\n\t\t\t\t\t() => {\n\t\t\t\t\t\tresolve();\n\t\t\t\t\t},\n\t\t\t\t\tthis\n\t\t\t\t);\n\t\t\t}\n\t\t});\n\t}\n\n\t@publicExtension()\n\t@finalExtension()\n\tpublic attachEventOnce(sEventId: string, oData: any, fnFunction?: Function, oListener?: any) {\n\t\t// eslint-disable-next-line prefer-rest-params\n\t\treturn this._oEventProvider.attachEventOnce(sEventId, oData, fnFunction as Function, oListener);\n\t}\n\t@publicExtension()\n\t@finalExtension()\n\tpublic attachEvent(sEventId: string, oData: any, fnFunction: Function, oListener: any) {\n\t\t// eslint-disable-next-line prefer-rest-params\n\t\treturn this._oEventProvider.attachEvent(sEventId, oData, fnFunction, oListener);\n\t}\n\t@publicExtension()\n\t@finalExtension()\n\tpublic detachEvent(sEventId: string, fnFunction: Function) {\n\t\t// eslint-disable-next-line prefer-rest-params\n\t\treturn this._oEventProvider.detachEvent(sEventId, fnFunction);\n\t}\n\tprivate registerContainer(oContainer: ManagedObject) {\n\t\tthis._oContainer = oContainer;\n\t\tthis._fnContainerDelegate = {\n\t\t\tonBeforeShow: () => {\n\t\t\t\tthis.bShown = false;\n\t\t\t\tthis._bIsPageReady = false;\n\t\t\t},\n\t\t\tonBeforeHide: () => {\n\t\t\t\tthis.bShown = false;\n\t\t\t\tthis._bIsPageReady = false;\n\t\t\t},\n\t\t\tonAfterShow: () => {\n\t\t\t\tthis.bShown = true;\n\t\t\t\tthis._checkPageReady(true);\n\t\t\t}\n\t\t};\n\t\tthis._oContainer.addEventDelegate(this._fnContainerDelegate);\n\t}\n\n\t@privateExtension()\n\t@extensible(OverrideExecution.Instead)\n\tpublic isContextExpected() {\n\t\treturn false;\n\t}\n\n\t@publicExtension()\n\tpublic checkPageReadyDebounced() {\n\t\tif (this.pageReadyTimer) {\n\t\t\tclearTimeout(this.pageReadyTimer);\n\t\t}\n\t\tthis.pageReadyTimer = setTimeout(() => {\n\t\t\tthis._checkPageReady();\n\t\t}, 200);\n\t}\n\n\tpublic _checkPageReady(bFromNav: boolean = false) {\n\t\tconst fnUIUpdated = () => {\n\t\t\t// Wait until the UI is no longer dirty\n\t\t\tif (!Core.getUIDirty()) {\n\t\t\t\t(Core as CoreEx).detachEvent(\"UIUpdated\", fnUIUpdated);\n\t\t\t\tthis._bWaitingForRefresh = false;\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tthis._checkPageReady();\n\t\t\t\t}, 20);\n\t\t\t}\n\t\t};\n\n\t\t// In case UIUpdate does not get called, check if UI is not dirty and then call _checkPageReady\n\t\tconst checkUIUpdated = () => {\n\t\t\tif (Core.getUIDirty()) {\n\t\t\t\tsetTimeout(checkUIUpdated, 500);\n\t\t\t} else if (this._bWaitingForRefresh) {\n\t\t\t\tthis._bWaitingForRefresh = false;\n\t\t\t\t(Core as CoreEx).detachEvent(\"UIUpdated\", fnUIUpdated);\n\t\t\t\tthis._checkPageReady();\n\t\t\t}\n\t\t};\n\n\t\tif (\n\t\t\tthis.bShown &&\n\t\t\tthis.queryWatcher.isDataReceived() !== false &&\n\t\t\tthis.bTablesChartsLoaded !== false &&\n\t\t\t(!this.isContextExpected() || this.bHasContext) // Either no context is expected or there is one\n\t\t) {\n\t\t\tif (this.queryWatcher.isDataReceived() === true && !bFromNav && !this._bWaitingForRefresh && Core.getUIDirty()) {\n\t\t\t\t// If we requested data we get notified as soon as the data arrived, so before the next rendering tick\n\t\t\t\tthis.queryWatcher.resetDataReceived();\n\t\t\t\tthis._bWaitingForRefresh = true;\n\t\t\t\t(Core as CoreEx).attachEvent(\"UIUpdated\", fnUIUpdated);\n\t\t\t\tsetTimeout(checkUIUpdated, 500);\n\t\t\t} else if (\n\t\t\t\t(!this._bWaitingForRefresh && Core.getUIDirty()) ||\n\t\t\t\tthis._nbWaits !== 0 ||\n\t\t\t\tTemplatedViewServiceFactory.getNumberOfViewsInCreationState() > 0 ||\n\t\t\t\tthis.queryWatcher.isSearchPending()\n\t\t\t) {\n\t\t\t\tthis._bWaitingForRefresh = true;\n\t\t\t\t(Core as CoreEx).attachEvent(\"UIUpdated\", fnUIUpdated);\n\t\t\t\tsetTimeout(checkUIUpdated, 500);\n\t\t\t} else if (!this._bWaitingForRefresh) {\n\t\t\t\t// In the case we're not waiting for any data (navigating back to a page we already have loaded)\n\t\t\t\t// just wait for a frame to fire the event.\n\t\t\t\tthis._bIsPageReady = true;\n\t\t\t\tthis._oEventProvider.fireEvent(\"pageReady\");\n\t\t\t}\n\t\t}\n\t}\n}\n\nexport default PageReadyControllerExtension;\n"]}
@@ -31,15 +31,21 @@ class PageReadyControllerExtension extends ControllerExtension {
31
31
  private bTablesChartsLoaded?: boolean;
32
32
  private pageReadyTimer: NodeJS.Timeout | undefined;
33
33
  private queryWatcher!: DataQueryWatcher;
34
+ private pageReadyTimeoutDefault = 7000;
35
+ private pageReadyTimeoutTimer?: number;
36
+ private pageReadyTimeout?: number;
34
37
 
35
38
  @methodOverride()
36
39
  public onInit() {
37
40
  this._nbWaits = 0;
38
41
  this._oEventProvider = this._oEventProvider ? this._oEventProvider : new EventProvider();
39
- this._oView = (this as any).base.getView();
42
+ this._oView = this.getView();
40
43
  this._oAppComponent = CommonUtils.getAppComponent(this._oView);
41
44
  this._oPageComponent = Component.getOwnerComponentFor(this._oView);
42
45
 
46
+ const manifestContent = this._oAppComponent.getManifest() as any;
47
+ this.pageReadyTimeout = manifestContent["sap.ui5"]?.pageReadyTimeout ?? this.pageReadyTimeoutDefault;
48
+
43
49
  if (this._oPageComponent && this._oPageComponent.attachContainerDefined) {
44
50
  this._oPageComponent.attachContainerDefined((oEvent: Event) => this.registerContainer(oEvent.getParameter("container")));
45
51
  } else {
@@ -47,7 +53,7 @@ class PageReadyControllerExtension extends ControllerExtension {
47
53
  }
48
54
 
49
55
  const oRootControlController = (this._oAppComponent.getRootControl() as View).getController() as any;
50
- const oPlaceholder = oRootControlController.getPlaceholder && oRootControlController.getPlaceholder();
56
+ const oPlaceholder = oRootControlController?.getPlaceholder && oRootControlController.getPlaceholder();
51
57
  if (oPlaceholder?.isPlaceholderDebugEnabled()) {
52
58
  this.attachEvent(
53
59
  "pageReady",
@@ -138,7 +144,16 @@ class PageReadyControllerExtension extends ControllerExtension {
138
144
  }
139
145
 
140
146
  @methodOverride("_routing")
141
- onAfterBinding(oBindingContext: Context) {
147
+ onAfterBinding(oBindingContext?: Context) {
148
+ // In case the page is rebind we need to clear the timer (eg: in FCL, the user can select 2 items successively in the list report)
149
+ if (this.pageReadyTimeoutTimer) {
150
+ clearTimeout(this.pageReadyTimeoutTimer);
151
+ }
152
+ this.pageReadyTimeoutTimer = setTimeout(() => {
153
+ Log.error(`The PageReady Event was not fired within the ${this.pageReadyTimeout} ms timeout . It has been forced.`);
154
+ this._oEventProvider.fireEvent("pageReady");
155
+ }, this.pageReadyTimeout);
156
+
142
157
  if (this._bAfterBindingAlreadyApplied) {
143
158
  return;
144
159
  }
@@ -156,6 +171,8 @@ class PageReadyControllerExtension extends ControllerExtension {
156
171
  "pageReady",
157
172
  null,
158
173
  () => {
174
+ clearTimeout(this.pageReadyTimeoutTimer);
175
+ this.pageReadyTimeoutTimer = undefined;
159
176
  this._bAfterBindingAlreadyApplied = false;
160
177
  this.queryWatcher.reset();
161
178
  },
@@ -67,7 +67,7 @@ sap.ui.define(["sap/base/Log", "sap/fe/core/formatters/FPMFormatter", "sap/fe/co
67
67
  interfaces: [],
68
68
  controls: [],
69
69
  elements: [],
70
- version: "1.102.7",
70
+ version: "1.102.8",
71
71
  noLibraryCSS: true,
72
72
  extensions: {
73
73
  //Configuration used for rule loading of Support Assistant