@sap-ux/preview-middleware 0.19.41 → 0.19.43

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (83) hide show
  1. package/dist/client/adp/add-fragment.js +46 -46
  2. package/dist/client/adp/api-handler.js +159 -159
  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/ControllerExtension.controller.js +210 -210
  6. package/dist/client/adp/controllers/ExtensionPoint.controller.js +139 -139
  7. package/dist/client/adp/controllers/FileExistsDialog.controller.js +66 -66
  8. package/dist/client/adp/dialog-factory.js +135 -135
  9. package/dist/client/adp/init-dialogs.js +163 -163
  10. package/dist/client/adp/quick-actions/add-new-subpage-quick-action-base.js +96 -96
  11. package/dist/client/adp/quick-actions/common/add-controller-to-page.js +60 -60
  12. package/dist/client/adp/quick-actions/common/create-page-action.js +54 -54
  13. package/dist/client/adp/quick-actions/common/op-add-custom-section.js +39 -39
  14. package/dist/client/adp/quick-actions/common/op-add-header-field.js +67 -67
  15. package/dist/client/adp/quick-actions/common/utils.js +18 -18
  16. package/dist/client/adp/quick-actions/control-types.js +23 -23
  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/add-new-subpage.js +81 -81
  20. package/dist/client/adp/quick-actions/fe-v2/change-table-actions.js +67 -67
  21. package/dist/client/adp/quick-actions/fe-v2/change-table-columns.js +101 -101
  22. package/dist/client/adp/quick-actions/fe-v2/create-table-action.js +107 -107
  23. package/dist/client/adp/quick-actions/fe-v2/create-table-custom-column.js +99 -99
  24. package/dist/client/adp/quick-actions/fe-v2/lr-enable-semantic-date-range-filter-bar.js +78 -78
  25. package/dist/client/adp/quick-actions/fe-v2/lr-enable-table-filtering.js +77 -77
  26. package/dist/client/adp/quick-actions/fe-v2/lr-enable-variant-management.js +69 -69
  27. package/dist/client/adp/quick-actions/fe-v2/lr-toggle-clear-filter-bar.js +59 -59
  28. package/dist/client/adp/quick-actions/fe-v2/op-enable-empty-row-mode.js +93 -93
  29. package/dist/client/adp/quick-actions/fe-v2/op-enable-variant-management.js +84 -84
  30. package/dist/client/adp/quick-actions/fe-v2/registry.js +77 -77
  31. package/dist/client/adp/quick-actions/fe-v2/utils.js +116 -116
  32. package/dist/client/adp/quick-actions/fe-v4/add-new-subpage.js +138 -138
  33. package/dist/client/adp/quick-actions/fe-v4/change-table-actions.js +79 -79
  34. package/dist/client/adp/quick-actions/fe-v4/change-table-columns.js +75 -75
  35. package/dist/client/adp/quick-actions/fe-v4/create-table-action.js +53 -53
  36. package/dist/client/adp/quick-actions/fe-v4/create-table-custom-column.js +49 -49
  37. package/dist/client/adp/quick-actions/fe-v4/enable-variant-management.js +81 -81
  38. package/dist/client/adp/quick-actions/fe-v4/lr-enable-semantic-date-range-filter-bar.js +56 -56
  39. package/dist/client/adp/quick-actions/fe-v4/lr-enable-table-filtering.js +84 -84
  40. package/dist/client/adp/quick-actions/fe-v4/lr-toggle-clear-filter-bar.js +53 -53
  41. package/dist/client/adp/quick-actions/fe-v4/op-enable-empty-row-mode.js +89 -89
  42. package/dist/client/adp/quick-actions/fe-v4/registry.js +60 -60
  43. package/dist/client/adp/quick-actions/fe-v4/utils.js +72 -72
  44. package/dist/client/adp/quick-actions/load.js +44 -44
  45. package/dist/client/adp/quick-actions/quick-action-base.js +64 -64
  46. package/dist/client/adp/utils.js +218 -218
  47. package/dist/client/cpe/additional-change-info/add-xml-additional-info.js +75 -75
  48. package/dist/client/cpe/changes/generic-change.js +328 -0
  49. package/dist/client/cpe/changes/generic-change.ts +462 -0
  50. package/dist/client/cpe/changes/index.js +10 -10
  51. package/dist/client/cpe/changes/service.js +75 -237
  52. package/dist/client/cpe/changes/service.ts +141 -403
  53. package/dist/client/cpe/changes/validator.js +39 -39
  54. package/dist/client/cpe/documentation.js +164 -164
  55. package/dist/client/cpe/feature-service.js +36 -36
  56. package/dist/client/cpe/logger.js +30 -30
  57. package/dist/client/cpe/outline/editable.js +37 -37
  58. package/dist/client/cpe/outline/nodes.js +203 -203
  59. package/dist/client/cpe/outline/service.ts +0 -1
  60. package/dist/client/cpe/quick-actions/quick-action-definition.js +4 -4
  61. package/dist/client/cpe/quick-actions/registry.js +143 -143
  62. package/dist/client/cpe/quick-actions/utils.js +92 -92
  63. package/dist/client/cpe/types.js +4 -4
  64. package/dist/client/cpe/ui5-utils.js +33 -33
  65. package/dist/client/cpe/utils.js +111 -111
  66. package/dist/client/flp/WorkspaceConnector.js +92 -92
  67. package/dist/client/flp/common.js +28 -28
  68. package/dist/client/flp/enableFakeConnector.js +89 -89
  69. package/dist/client/flp/homepage/Component.js +14 -14
  70. package/dist/client/flp/initCdm.js +117 -117
  71. package/dist/client/flp/initConnectors.js +28 -28
  72. package/dist/client/flp/initRta.js +178 -178
  73. package/dist/client/i18n.js +56 -56
  74. package/dist/client/messagebundle.properties +21 -0
  75. package/dist/client/thirdparty/@sap-ux-private/control-property-editor-common.js +2 -4
  76. package/dist/client/utils/additional-change-info.js +54 -54
  77. package/dist/client/utils/application.js +32 -32
  78. package/dist/client/utils/core.js +84 -84
  79. package/dist/client/utils/error.js +19 -19
  80. package/dist/client/utils/fe-v2.js +56 -56
  81. package/dist/client/utils/fe-v4.js +140 -140
  82. package/dist/client/utils/version.js +104 -104
  83. package/package.json +4 -4
@@ -1,48 +1,48 @@
1
- "use strict";
2
-
3
- sap.ui.define(["sap/ui/rta/command/CommandFactory", "./utils", "./dialog-factory", "sap/ui/rta/plugin/AddXMLPlugin"], function (CommandFactory, ___utils, ___dialog_factory, AddXMLPlugin) {
4
- "use strict";
5
-
6
- const createDeferred = ___utils["createDeferred"];
7
- const DialogFactory = ___dialog_factory["DialogFactory"];
8
- const DialogNames = ___dialog_factory["DialogNames"];
9
- /**
10
- * Initializes the AddXMLPlugin and includes it in the Runtime Authoring (RTA) plugins.
11
- *
12
- * @param rta Runtime Authoring instance
13
- */
14
- function initAddXMLPlugin(rta) {
15
- const flexSettings = rta.getFlexSettings();
16
- const commandFactory = new CommandFactory({
17
- flexSettings
18
- });
19
- const plugin = new AddXMLPlugin({
20
- commandFactory,
21
- fragmentHandler: async overlay => await handleFragmentCreation(rta, overlay)
22
- });
23
- const plugins = rta.getPlugins();
24
- plugins.addXMLPlugin = plugin;
25
- rta.setPlugins(plugins);
26
- }
27
-
28
- /**
29
- * Handles the creation of a fragment by opening a dialog and resolving the deferred data.
30
- *
31
- * @param rta Runtime Authoring instance
32
- * @param overlay UI5 Element overlay
33
- * @returns A promise that resolves with DeferredXmlFragmentData
34
- */
35
- async function handleFragmentCreation(rta, overlay) {
36
- const deferred = createDeferred();
37
- await DialogFactory.createDialog(overlay, rta, DialogNames.ADD_FRAGMENT, {
38
- deferred
39
- });
40
- return deferred.promise;
41
- }
42
- var __exports = {
43
- __esModule: true
44
- };
45
- __exports.initAddXMLPlugin = initAddXMLPlugin;
46
- return __exports;
1
+ "use strict";
2
+
3
+ sap.ui.define(["sap/ui/rta/command/CommandFactory", "./utils", "./dialog-factory", "sap/ui/rta/plugin/AddXMLPlugin"], function (CommandFactory, ___utils, ___dialog_factory, AddXMLPlugin) {
4
+ "use strict";
5
+
6
+ const createDeferred = ___utils["createDeferred"];
7
+ const DialogFactory = ___dialog_factory["DialogFactory"];
8
+ const DialogNames = ___dialog_factory["DialogNames"];
9
+ /**
10
+ * Initializes the AddXMLPlugin and includes it in the Runtime Authoring (RTA) plugins.
11
+ *
12
+ * @param rta Runtime Authoring instance
13
+ */
14
+ function initAddXMLPlugin(rta) {
15
+ const flexSettings = rta.getFlexSettings();
16
+ const commandFactory = new CommandFactory({
17
+ flexSettings
18
+ });
19
+ const plugin = new AddXMLPlugin({
20
+ commandFactory,
21
+ fragmentHandler: async overlay => await handleFragmentCreation(rta, overlay)
22
+ });
23
+ const plugins = rta.getPlugins();
24
+ plugins.addXMLPlugin = plugin;
25
+ rta.setPlugins(plugins);
26
+ }
27
+
28
+ /**
29
+ * Handles the creation of a fragment by opening a dialog and resolving the deferred data.
30
+ *
31
+ * @param rta Runtime Authoring instance
32
+ * @param overlay UI5 Element overlay
33
+ * @returns A promise that resolves with DeferredXmlFragmentData
34
+ */
35
+ async function handleFragmentCreation(rta, overlay) {
36
+ const deferred = createDeferred();
37
+ await DialogFactory.createDialog(overlay, rta, DialogNames.ADD_FRAGMENT, {
38
+ deferred
39
+ });
40
+ return deferred.promise;
41
+ }
42
+ var __exports = {
43
+ __esModule: true
44
+ };
45
+ __exports.initAddXMLPlugin = initAddXMLPlugin;
46
+ return __exports;
47
47
  });
48
48
  //# sourceMappingURL=add-fragment.js.map
@@ -1,161 +1,161 @@
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
- const params = new URLSearchParams({
128
- name: controllerName
129
- });
130
- const url = `${ApiEndpoints.CODE_EXT}?${params.toString()}`;
131
- return request(url, RequestMethod.GET);
132
- }
133
-
134
- /**
135
- * Writes a change object to the project's workspace
136
- *
137
- * @param data Data to be send to the server
138
- * @returns Generic Promise<T>
139
- */
140
- async function writeChange(data) {
141
- return request(ApiEndpoints.CHANGES, RequestMethod.POST, {
142
- change: data
143
- });
144
- }
145
- var __exports = {
146
- __esModule: true
147
- };
148
- __exports.ApiEndpoints = ApiEndpoints;
149
- __exports.RequestMethod = RequestMethod;
150
- __exports.request = request;
151
- __exports.getFragments = getFragments;
152
- __exports.writeFragment = writeFragment;
153
- __exports.getManifestAppdescr = getManifestAppdescr;
154
- __exports.readControllers = readControllers;
155
- __exports.writeController = writeController;
156
- __exports.getDataSourceAnnotationFileMap = getDataSourceAnnotationFileMap;
157
- __exports.getExistingController = getExistingController;
158
- __exports.writeChange = writeChange;
159
- 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
+ const params = new URLSearchParams({
128
+ name: controllerName
129
+ });
130
+ const url = `${ApiEndpoints.CODE_EXT}?${params.toString()}`;
131
+ return request(url, RequestMethod.GET);
132
+ }
133
+
134
+ /**
135
+ * Writes a change object to the project's workspace
136
+ *
137
+ * @param data Data to be send to the server
138
+ * @returns Generic Promise<T>
139
+ */
140
+ async function writeChange(data) {
141
+ return request(ApiEndpoints.CHANGES, RequestMethod.POST, {
142
+ change: data
143
+ });
144
+ }
145
+ var __exports = {
146
+ __esModule: true
147
+ };
148
+ __exports.ApiEndpoints = ApiEndpoints;
149
+ __exports.RequestMethod = RequestMethod;
150
+ __exports.request = request;
151
+ __exports.getFragments = getFragments;
152
+ __exports.writeFragment = writeFragment;
153
+ __exports.getManifestAppdescr = getManifestAppdescr;
154
+ __exports.readControllers = readControllers;
155
+ __exports.writeController = writeController;
156
+ __exports.getDataSourceAnnotationFileMap = getDataSourceAnnotationFileMap;
157
+ __exports.getExistingController = getExistingController;
158
+ __exports.writeChange = writeChange;
159
+ return __exports;
160
160
  });
161
161
  //# 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