@sap-ux/preview-middleware 0.17.13 → 0.17.15

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 (67) hide show
  1. package/dist/base/flp.js +8 -4
  2. package/dist/client/adp/api-handler.js +153 -153
  3. package/dist/client/adp/command-executor.js +75 -75
  4. package/dist/client/adp/control-utils.js +44 -44
  5. package/dist/client/adp/controllers/BaseDialog.controller.js +187 -187
  6. package/dist/client/adp/controllers/ControllerExtension.controller.js +213 -213
  7. package/dist/client/adp/controllers/ExtensionPoint.controller.js +138 -138
  8. package/dist/client/adp/controllers/FileExistsDialog.controller.js +66 -66
  9. package/dist/client/adp/dialog-factory.js +122 -122
  10. package/dist/client/adp/init-dialogs.js +100 -100
  11. package/dist/client/adp/quick-actions/common/add-controller-to-page.js +55 -55
  12. package/dist/client/adp/quick-actions/common/create-page-action.js +50 -50
  13. package/dist/client/adp/quick-actions/common/op-add-custom-section.js +36 -36
  14. package/dist/client/adp/quick-actions/common/op-add-header-field.js +48 -48
  15. package/dist/client/adp/quick-actions/common/utils.js +18 -18
  16. package/dist/client/adp/quick-actions/control-types.js +21 -21
  17. package/dist/client/adp/quick-actions/dialog-enablement-validator.js +24 -24
  18. package/dist/client/adp/quick-actions/enablement-validator.js +4 -4
  19. package/dist/client/adp/quick-actions/fe-v2/change-table-columns.js +101 -101
  20. package/dist/client/adp/quick-actions/fe-v2/create-table-action.js +70 -70
  21. package/dist/client/adp/quick-actions/fe-v2/create-table-custom-column.js +96 -96
  22. package/dist/client/adp/quick-actions/fe-v2/lr-enable-semantic-date-range-filter-bar.js +78 -78
  23. package/dist/client/adp/quick-actions/fe-v2/lr-enable-table-filtering.js +77 -77
  24. package/dist/client/adp/quick-actions/fe-v2/lr-enable-variant-management.js +69 -69
  25. package/dist/client/adp/quick-actions/fe-v2/lr-toggle-clear-filter-bar.js +58 -58
  26. package/dist/client/adp/quick-actions/fe-v2/op-enable-empty-row-mode.js +93 -93
  27. package/dist/client/adp/quick-actions/fe-v2/op-enable-variant-management.js +81 -81
  28. package/dist/client/adp/quick-actions/fe-v2/registry.js +75 -75
  29. package/dist/client/adp/quick-actions/fe-v2/utils.js +95 -95
  30. package/dist/client/adp/quick-actions/fe-v4/change-table-columns.js +73 -73
  31. package/dist/client/adp/quick-actions/fe-v4/create-table-action.js +49 -49
  32. package/dist/client/adp/quick-actions/fe-v4/create-table-custom-column.js +46 -46
  33. package/dist/client/adp/quick-actions/fe-v4/enable-variant-management.js +81 -81
  34. package/dist/client/adp/quick-actions/fe-v4/lr-enable-semantic-date-range-filter-bar.js +55 -55
  35. package/dist/client/adp/quick-actions/fe-v4/lr-enable-table-filtering.js +82 -82
  36. package/dist/client/adp/quick-actions/fe-v4/lr-toggle-clear-filter-bar.js +52 -52
  37. package/dist/client/adp/quick-actions/fe-v4/op-enable-empty-row-mode.js +89 -89
  38. package/dist/client/adp/quick-actions/fe-v4/registry.js +58 -58
  39. package/dist/client/adp/quick-actions/fe-v4/utils.js +47 -47
  40. package/dist/client/adp/quick-actions/load.js +44 -44
  41. package/dist/client/adp/quick-actions/quick-action-base.js +53 -53
  42. package/dist/client/adp/utils.js +160 -160
  43. package/dist/client/cpe/changes/index.js +10 -10
  44. package/dist/client/cpe/changes/validator.js +39 -39
  45. package/dist/client/cpe/documentation.js +164 -164
  46. package/dist/client/cpe/feature-service.js +36 -36
  47. package/dist/client/cpe/logger.js +30 -30
  48. package/dist/client/cpe/outline/editable.js +37 -37
  49. package/dist/client/cpe/outline/nodes.js +222 -222
  50. package/dist/client/cpe/quick-actions/quick-action-definition.js +4 -4
  51. package/dist/client/cpe/quick-actions/registry.js +143 -143
  52. package/dist/client/cpe/quick-actions/utils.js +92 -92
  53. package/dist/client/cpe/types.js +4 -4
  54. package/dist/client/cpe/ui5-utils.js +33 -33
  55. package/dist/client/cpe/utils.js +138 -138
  56. package/dist/client/flp/WorkspaceConnector.js +86 -86
  57. package/dist/client/flp/common.js +28 -28
  58. package/dist/client/flp/enableFakeConnector.js +83 -83
  59. package/dist/client/flp/initConnectors.js +30 -30
  60. package/dist/client/flp/initRta.js +178 -178
  61. package/dist/client/i18n.js +56 -56
  62. package/dist/client/utils/application.js +32 -32
  63. package/dist/client/utils/core.js +68 -68
  64. package/dist/client/utils/error.js +19 -19
  65. package/dist/client/utils/fe-v4.js +118 -118
  66. package/dist/client/utils/version.js +102 -102
  67. package/package.json +9 -7
package/dist/base/flp.js CHANGED
@@ -238,8 +238,8 @@ class FlpSandbox {
238
238
  this.router.use(config_1.PREVIEW_URL.client.path, (0, express_1.static)(config_1.PREVIEW_URL.client.local));
239
239
  // add route for the sandbox html
240
240
  this.router.get(this.config.path, (async (req, res, next) => {
241
- // karma (connect API) has no request query property
242
- if (req.query && !req.query['sap-ui-xx-viewCache']) {
241
+ // connect API (karma test runner) has no request query property
242
+ if ('query' in req && 'redirect' in res && !req.query['sap-ui-xx-viewCache']) {
243
243
  // Redirect to the same URL but add the necessary parameter
244
244
  const params = structuredClone(req.query);
245
245
  params['sap-ui-xx-viewCache'] = 'false';
@@ -255,7 +255,11 @@ class FlpSandbox {
255
255
  next();
256
256
  }
257
257
  else {
258
- const ui5Version = await this.getUi5Version(req.protocol, req.headers.host, req['ui5-patched-router']?.baseUrl);
258
+ const ui5Version = await this.getUi5Version(
259
+ //use protocol from request header referer as fallback for connect API (karma test runner)
260
+ 'protocol' in req
261
+ ? req.protocol
262
+ : req.headers.referer?.substring(0, req.headers.referer.indexOf(':')) ?? 'http', req.headers.host, 'ui5-patched-router' in req ? req['ui5-patched-router']?.baseUrl : undefined);
259
263
  const html = (0, ejs_1.render)(this.getSandboxTemplate(ui5Version.major), this.templateConfig);
260
264
  this.sendResponse(res, 'text/html', 200, html);
261
265
  }
@@ -424,7 +428,7 @@ class FlpSandbox {
424
428
  const initTemplate = (0, fs_1.readFileSync)((0, path_1.join)(__dirname, '../../templates/test/testsuite.qunit.js'), 'utf-8');
425
429
  const config = (0, test_1.mergeTestConfigDefaults)(testsuiteConfig);
426
430
  this.logger.debug(`Add route for ${config.path}`);
427
- this.router.get(config.path, (async (_req, res) => {
431
+ this.router.get(config.path, (async (_req, res, _next) => {
428
432
  this.logger.debug(`Serving test route: ${config.path}`);
429
433
  const templateConfig = {
430
434
  basePath: this.templateConfig.basePath,
@@ -1,155 +1,155 @@
1
- "use strict";
2
-
3
- sap.ui.define(["../utils/error"], function (___utils_error) {
4
- "use strict";
5
-
6
- const getError = ___utils_error["getError"];
7
- var ApiEndpoints = /*#__PURE__*/function (ApiEndpoints) {
8
- ApiEndpoints["CHANGES"] = "/preview/api/changes";
9
- ApiEndpoints["FRAGMENT"] = "/adp/api/fragment";
10
- ApiEndpoints["CONTROLLER"] = "/adp/api/controller";
11
- ApiEndpoints["CODE_EXT"] = "/adp/api/code_ext";
12
- ApiEndpoints["ANNOTATION_FILE"] = "/adp/api/annotation";
13
- ApiEndpoints["MANIFEST_APP_DESCRIPTOR"] = "/manifest.appdescr_variant";
14
- return ApiEndpoints;
15
- }(ApiEndpoints || {});
16
- var RequestMethod = /*#__PURE__*/function (RequestMethod) {
17
- RequestMethod["GET"] = "GET";
18
- RequestMethod["PUT"] = "PUT";
19
- RequestMethod["POST"] = "POST";
20
- RequestMethod["PATCH"] = "PATCH";
21
- RequestMethod["DELETE"] = "DELETE";
22
- return RequestMethod;
23
- }(RequestMethod || {});
24
- /**
25
- * Requests a given endpoint
26
- *
27
- * @param endpoint API Endpoint
28
- * @param method RequestMethod
29
- * @param data Data to be sent to the server
30
- * @returns Data from the server request
31
- */
32
- async function request(endpoint, method, data) {
33
- const config = {
34
- method,
35
- body: JSON.stringify(data),
36
- headers: {
37
- 'content-type': 'application/json'
38
- }
39
- };
40
- try {
41
- const response = await fetch(endpoint, config);
42
- if (!response.ok) {
43
- const errorData = await response.json();
44
- const message = errorData?.message ?? '';
45
- throw new Error(`Request failed, status: ${response.status}. ${message}`.trim());
46
- }
47
- switch (method) {
48
- case RequestMethod.GET:
49
- return response.json();
50
- case RequestMethod.POST:
51
- /**
52
- * Since POST usually creates something
53
- * and returns nothing (or a message) we just parse the text from res.send(msg)
54
- */
55
- return response.text();
56
- default:
57
- return response.json();
58
- }
59
- } catch (e) {
60
- throw getError(e);
61
- }
62
- }
63
-
64
- /**
65
- * Retrieves all XML fragments from the project's workspace
66
- *
67
- * @returns Generic Promise<T>
68
- */
69
- async function getFragments() {
70
- return request(ApiEndpoints.FRAGMENT, RequestMethod.GET);
71
- }
72
-
73
- /**
74
- * Writes an XML fragment to the project's workspace
75
- *
76
- * @param data Data to be send to the server
77
- * @returns Generic Promise<T>
78
- */
79
- async function writeFragment(data) {
80
- return request(ApiEndpoints.FRAGMENT, RequestMethod.POST, data);
81
- }
82
-
83
- /**
84
- * Retrieves manifest.appdescr_variant from the project's workspace
85
- *
86
- * @returns Generic Promise<T>
87
- */
88
- async function getManifestAppdescr() {
89
- return request(ApiEndpoints.MANIFEST_APP_DESCRIPTOR, RequestMethod.GET);
90
- }
91
-
92
- /**
93
- * Retrieves all controller extensions from the project's workspace
94
- *
95
- * @returns Generic Promise<T>
96
- */
97
- async function readControllers() {
98
- return request(ApiEndpoints.CONTROLLER, RequestMethod.GET);
99
- }
100
-
101
- /**
102
- * Writes a Controller to the project's workspace
103
- *
104
- * @param data Data to be send to the server
105
- * @returns Generic Promise<T>
106
- */
107
- async function writeController(data) {
108
- return request(ApiEndpoints.CONTROLLER, RequestMethod.POST, data);
109
- }
110
-
111
- /**
112
- * Writes a new annotation file to the project's workspace
113
- *
114
- * @returns Generic Promise<DataSourceAnnotationMap>
115
- */
116
- async function getDataSourceAnnotationFileMap() {
117
- return request(ApiEndpoints.ANNOTATION_FILE, RequestMethod.GET);
118
- }
119
-
120
- /**
121
- * Checks for existing controller in the project's workspace
122
- *
123
- * @param controllerName Name of the controller
124
- * @returns {CodeExtResponse} Returns path to existing controller if found
125
- */
126
- async function getExistingController(controllerName) {
127
- return request(`${ApiEndpoints.CODE_EXT}/${controllerName}`, RequestMethod.GET);
128
- }
129
-
130
- /**
131
- * Writes a change object to the project's workspace
132
- *
133
- * @param data Data to be send to the server
134
- * @returns Generic Promise<T>
135
- */
136
- async function writeChange(data) {
137
- return request(ApiEndpoints.CHANGES, RequestMethod.POST, data);
138
- }
139
- var __exports = {
140
- __esModule: true
141
- };
142
- __exports.ApiEndpoints = ApiEndpoints;
143
- __exports.RequestMethod = RequestMethod;
144
- __exports.request = request;
145
- __exports.getFragments = getFragments;
146
- __exports.writeFragment = writeFragment;
147
- __exports.getManifestAppdescr = getManifestAppdescr;
148
- __exports.readControllers = readControllers;
149
- __exports.writeController = writeController;
150
- __exports.getDataSourceAnnotationFileMap = getDataSourceAnnotationFileMap;
151
- __exports.getExistingController = getExistingController;
152
- __exports.writeChange = writeChange;
153
- return __exports;
1
+ "use strict";
2
+
3
+ sap.ui.define(["../utils/error"], function (___utils_error) {
4
+ "use strict";
5
+
6
+ const getError = ___utils_error["getError"];
7
+ var ApiEndpoints = /*#__PURE__*/function (ApiEndpoints) {
8
+ ApiEndpoints["CHANGES"] = "/preview/api/changes";
9
+ ApiEndpoints["FRAGMENT"] = "/adp/api/fragment";
10
+ ApiEndpoints["CONTROLLER"] = "/adp/api/controller";
11
+ ApiEndpoints["CODE_EXT"] = "/adp/api/code_ext";
12
+ ApiEndpoints["ANNOTATION_FILE"] = "/adp/api/annotation";
13
+ ApiEndpoints["MANIFEST_APP_DESCRIPTOR"] = "/manifest.appdescr_variant";
14
+ return ApiEndpoints;
15
+ }(ApiEndpoints || {});
16
+ var RequestMethod = /*#__PURE__*/function (RequestMethod) {
17
+ RequestMethod["GET"] = "GET";
18
+ RequestMethod["PUT"] = "PUT";
19
+ RequestMethod["POST"] = "POST";
20
+ RequestMethod["PATCH"] = "PATCH";
21
+ RequestMethod["DELETE"] = "DELETE";
22
+ return RequestMethod;
23
+ }(RequestMethod || {});
24
+ /**
25
+ * Requests a given endpoint
26
+ *
27
+ * @param endpoint API Endpoint
28
+ * @param method RequestMethod
29
+ * @param data Data to be sent to the server
30
+ * @returns Data from the server request
31
+ */
32
+ async function request(endpoint, method, data) {
33
+ const config = {
34
+ method,
35
+ body: JSON.stringify(data),
36
+ headers: {
37
+ 'content-type': 'application/json'
38
+ }
39
+ };
40
+ try {
41
+ const response = await fetch(endpoint, config);
42
+ if (!response.ok) {
43
+ const errorData = await response.json();
44
+ const message = errorData?.message ?? '';
45
+ throw new Error(`Request failed, status: ${response.status}. ${message}`.trim());
46
+ }
47
+ switch (method) {
48
+ case RequestMethod.GET:
49
+ return response.json();
50
+ case RequestMethod.POST:
51
+ /**
52
+ * Since POST usually creates something
53
+ * and returns nothing (or a message) we just parse the text from res.send(msg)
54
+ */
55
+ return response.text();
56
+ default:
57
+ return response.json();
58
+ }
59
+ } catch (e) {
60
+ throw getError(e);
61
+ }
62
+ }
63
+
64
+ /**
65
+ * Retrieves all XML fragments from the project's workspace
66
+ *
67
+ * @returns Generic Promise<T>
68
+ */
69
+ async function getFragments() {
70
+ return request(ApiEndpoints.FRAGMENT, RequestMethod.GET);
71
+ }
72
+
73
+ /**
74
+ * Writes an XML fragment to the project's workspace
75
+ *
76
+ * @param data Data to be send to the server
77
+ * @returns Generic Promise<T>
78
+ */
79
+ async function writeFragment(data) {
80
+ return request(ApiEndpoints.FRAGMENT, RequestMethod.POST, data);
81
+ }
82
+
83
+ /**
84
+ * Retrieves manifest.appdescr_variant from the project's workspace
85
+ *
86
+ * @returns Generic Promise<T>
87
+ */
88
+ async function getManifestAppdescr() {
89
+ return request(ApiEndpoints.MANIFEST_APP_DESCRIPTOR, RequestMethod.GET);
90
+ }
91
+
92
+ /**
93
+ * Retrieves all controller extensions from the project's workspace
94
+ *
95
+ * @returns Generic Promise<T>
96
+ */
97
+ async function readControllers() {
98
+ return request(ApiEndpoints.CONTROLLER, RequestMethod.GET);
99
+ }
100
+
101
+ /**
102
+ * Writes a Controller to the project's workspace
103
+ *
104
+ * @param data Data to be send to the server
105
+ * @returns Generic Promise<T>
106
+ */
107
+ async function writeController(data) {
108
+ return request(ApiEndpoints.CONTROLLER, RequestMethod.POST, data);
109
+ }
110
+
111
+ /**
112
+ * Writes a new annotation file to the project's workspace
113
+ *
114
+ * @returns Generic Promise<DataSourceAnnotationMap>
115
+ */
116
+ async function getDataSourceAnnotationFileMap() {
117
+ return request(ApiEndpoints.ANNOTATION_FILE, RequestMethod.GET);
118
+ }
119
+
120
+ /**
121
+ * Checks for existing controller in the project's workspace
122
+ *
123
+ * @param controllerName Name of the controller
124
+ * @returns {CodeExtResponse} Returns path to existing controller if found
125
+ */
126
+ async function getExistingController(controllerName) {
127
+ return request(`${ApiEndpoints.CODE_EXT}/${controllerName}`, RequestMethod.GET);
128
+ }
129
+
130
+ /**
131
+ * Writes a change object to the project's workspace
132
+ *
133
+ * @param data Data to be send to the server
134
+ * @returns Generic Promise<T>
135
+ */
136
+ async function writeChange(data) {
137
+ return request(ApiEndpoints.CHANGES, RequestMethod.POST, data);
138
+ }
139
+ var __exports = {
140
+ __esModule: true
141
+ };
142
+ __exports.ApiEndpoints = ApiEndpoints;
143
+ __exports.RequestMethod = RequestMethod;
144
+ __exports.request = request;
145
+ __exports.getFragments = getFragments;
146
+ __exports.writeFragment = writeFragment;
147
+ __exports.getManifestAppdescr = getManifestAppdescr;
148
+ __exports.readControllers = readControllers;
149
+ __exports.writeController = writeController;
150
+ __exports.getDataSourceAnnotationFileMap = getDataSourceAnnotationFileMap;
151
+ __exports.getExistingController = getExistingController;
152
+ __exports.writeChange = writeChange;
153
+ return __exports;
154
154
  });
155
155
  //# sourceMappingURL=api-handler.js.map
@@ -1,77 +1,77 @@
1
- "use strict";
2
-
3
- sap.ui.define(["sap/m/MessageToast", "sap/ui/rta/command/CommandFactory", "../utils/error"], function (MessageToast, CommandFactory, ___utils_error) {
4
- "use strict";
5
-
6
- const getError = ___utils_error["getError"];
7
- /**
8
- * Class responsible for handling rta calls
9
- */
10
- class CommandExecutor {
11
- /**
12
- *
13
- * @param rta Runtime Authoring
14
- */
15
- constructor(rta) {
16
- this.rta = rta;
17
- }
18
-
19
- /**
20
- * Generates command based on given values
21
- *
22
- * @param runtimeControl Managed object
23
- * @param commandName Command name
24
- * @param modifiedValue Modified value/s
25
- * @param designMetadata Design time metadata
26
- * @param flexSettings Additional flex settings
27
- */
28
- async getCommand(runtimeControl, commandName, modifiedValue, designMetadata, flexSettings) {
29
- try {
30
- return await CommandFactory.getCommandFor(runtimeControl, commandName, modifiedValue, designMetadata, flexSettings);
31
- } catch (e) {
32
- const error = getError(e);
33
- const msgToastErrorMsg = `Could not get command for '${commandName}'. ${error.message}`;
34
- error.message = msgToastErrorMsg;
35
- MessageToast.show(msgToastErrorMsg);
36
- throw error;
37
- }
38
- }
39
-
40
- /**
41
- * Creates composite command without nested commands
42
- *
43
- * @param runtimeControl Managed object
44
- */
45
- async createCompositeCommand(runtimeControl) {
46
- try {
47
- return await CommandFactory.getCommandFor(runtimeControl, 'composite');
48
- } catch (e) {
49
- const error = getError(e);
50
- const msgToastErrorMsg = `Could not get composite command'. ${error.message}`;
51
- error.message = msgToastErrorMsg;
52
- MessageToast.show(msgToastErrorMsg);
53
- throw error;
54
- }
55
- }
56
-
57
- /**
58
- * Pushed and executes the provided command
59
- *
60
- * @param command Command
61
- */
62
- async pushAndExecuteCommand(command) {
63
- try {
64
- /**
65
- * The change will have pending state and will only be saved to the workspace when the user clicks save icon
66
- */
67
- await this.rta.getCommandStack().pushAndExecute(command);
68
- } catch (e) {
69
- const error = getError(e);
70
- MessageToast.show(error.message);
71
- throw error;
72
- }
73
- }
74
- }
75
- return CommandExecutor;
1
+ "use strict";
2
+
3
+ sap.ui.define(["sap/m/MessageToast", "sap/ui/rta/command/CommandFactory", "../utils/error"], function (MessageToast, CommandFactory, ___utils_error) {
4
+ "use strict";
5
+
6
+ const getError = ___utils_error["getError"];
7
+ /**
8
+ * Class responsible for handling rta calls
9
+ */
10
+ class CommandExecutor {
11
+ /**
12
+ *
13
+ * @param rta Runtime Authoring
14
+ */
15
+ constructor(rta) {
16
+ this.rta = rta;
17
+ }
18
+
19
+ /**
20
+ * Generates command based on given values
21
+ *
22
+ * @param runtimeControl Managed object
23
+ * @param commandName Command name
24
+ * @param modifiedValue Modified value/s
25
+ * @param designMetadata Design time metadata
26
+ * @param flexSettings Additional flex settings
27
+ */
28
+ async getCommand(runtimeControl, commandName, modifiedValue, designMetadata, flexSettings) {
29
+ try {
30
+ return await CommandFactory.getCommandFor(runtimeControl, commandName, modifiedValue, designMetadata, flexSettings);
31
+ } catch (e) {
32
+ const error = getError(e);
33
+ const msgToastErrorMsg = `Could not get command for '${commandName}'. ${error.message}`;
34
+ error.message = msgToastErrorMsg;
35
+ MessageToast.show(msgToastErrorMsg);
36
+ throw error;
37
+ }
38
+ }
39
+
40
+ /**
41
+ * Creates composite command without nested commands
42
+ *
43
+ * @param runtimeControl Managed object
44
+ */
45
+ async createCompositeCommand(runtimeControl) {
46
+ try {
47
+ return await CommandFactory.getCommandFor(runtimeControl, 'composite');
48
+ } catch (e) {
49
+ const error = getError(e);
50
+ const msgToastErrorMsg = `Could not get composite command'. ${error.message}`;
51
+ error.message = msgToastErrorMsg;
52
+ MessageToast.show(msgToastErrorMsg);
53
+ throw error;
54
+ }
55
+ }
56
+
57
+ /**
58
+ * Pushed and executes the provided command
59
+ *
60
+ * @param command Command
61
+ */
62
+ async pushAndExecuteCommand(command) {
63
+ try {
64
+ /**
65
+ * The change will have pending state and will only be saved to the workspace when the user clicks save icon
66
+ */
67
+ await this.rta.getCommandStack().pushAndExecute(command);
68
+ } catch (e) {
69
+ const error = getError(e);
70
+ MessageToast.show(error.message);
71
+ throw error;
72
+ }
73
+ }
74
+ }
75
+ return CommandExecutor;
76
76
  });
77
77
  //# sourceMappingURL=command-executor.js.map
@@ -1,46 +1,46 @@
1
- "use strict";
2
-
3
- sap.ui.define([], function () {
4
- "use strict";
5
-
6
- /**
7
- * Handles calling control specific functions for retrieving control data
8
- */
9
- class ControlUtils {
10
- /**
11
- * Returns ManagedObject runtime control
12
- *
13
- * @param overlayControl Overlay
14
- * @returns {ManagedObject} Managed Object instance
15
- */
16
- static getRuntimeControl(overlayControl) {
17
- let runtimeControl;
18
- if (overlayControl.getElementInstance) {
19
- runtimeControl = overlayControl.getElementInstance();
20
- } else {
21
- runtimeControl = overlayControl.getElement();
22
- }
23
- return runtimeControl;
24
- }
25
-
26
- /**
27
- * Returns control aggregation names in an array
28
- *
29
- * @param control Managed Object runtime control
30
- * @param name Aggregation name
31
- * @returns Array of control aggregations
32
- */
33
- static getControlAggregationByName(control, name) {
34
- let result = [];
35
- const aggregation = (control ? control.getMetadata().getAllAggregations() : {})[name];
36
- if (aggregation) {
37
- // This executes a _sGetter function that can vary from control to control (_sGetter can be: getContent, getItems, etc)
38
- const names = aggregation._sGetter && control[aggregation._sGetter]() || [];
39
- result = Array.isArray(names) ? names : [names];
40
- }
41
- return result;
42
- }
43
- }
44
- return ControlUtils;
1
+ "use strict";
2
+
3
+ sap.ui.define([], function () {
4
+ "use strict";
5
+
6
+ /**
7
+ * Handles calling control specific functions for retrieving control data
8
+ */
9
+ class ControlUtils {
10
+ /**
11
+ * Returns ManagedObject runtime control
12
+ *
13
+ * @param overlayControl Overlay
14
+ * @returns {ManagedObject} Managed Object instance
15
+ */
16
+ static getRuntimeControl(overlayControl) {
17
+ let runtimeControl;
18
+ if (overlayControl.getElementInstance) {
19
+ runtimeControl = overlayControl.getElementInstance();
20
+ } else {
21
+ runtimeControl = overlayControl.getElement();
22
+ }
23
+ return runtimeControl;
24
+ }
25
+
26
+ /**
27
+ * Returns control aggregation names in an array
28
+ *
29
+ * @param control Managed Object runtime control
30
+ * @param name Aggregation name
31
+ * @returns Array of control aggregations
32
+ */
33
+ static getControlAggregationByName(control, name) {
34
+ let result = [];
35
+ const aggregation = (control ? control.getMetadata().getAllAggregations() : {})[name];
36
+ if (aggregation) {
37
+ // This executes a _sGetter function that can vary from control to control (_sGetter can be: getContent, getItems, etc)
38
+ const names = aggregation._sGetter && control[aggregation._sGetter]() || [];
39
+ result = Array.isArray(names) ? names : [names];
40
+ }
41
+ return result;
42
+ }
43
+ }
44
+ return ControlUtils;
45
45
  });
46
46
  //# sourceMappingURL=control-utils.js.map