@sap-ux/preview-middleware 0.16.161 → 0.16.163

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 (78) hide show
  1. package/dist/base/flex.js +28 -7
  2. package/dist/client/adp/api-handler.js +164 -142
  3. package/dist/client/adp/api-handler.ts +31 -0
  4. package/dist/client/adp/command-executor.js +75 -75
  5. package/dist/client/adp/control-utils.js +44 -44
  6. package/dist/client/adp/controllers/BaseDialog.controller.js +187 -187
  7. package/dist/client/adp/controllers/BaseDialog.controller.ts +1 -2
  8. package/dist/client/adp/controllers/ControllerExtension.controller.js +213 -213
  9. package/dist/client/adp/controllers/ExtensionPoint.controller.js +138 -138
  10. package/dist/client/adp/controllers/FileExistsDialog.controller.js +71 -0
  11. package/dist/client/adp/controllers/FileExistsDialog.controller.ts +92 -0
  12. package/dist/client/adp/dialog-factory.js +122 -113
  13. package/dist/client/adp/dialog-factory.ts +15 -7
  14. package/dist/client/adp/init-dialogs.js +100 -100
  15. package/dist/client/adp/quick-actions/common/add-controller-to-page.js +55 -55
  16. package/dist/client/adp/quick-actions/common/add-new-annotation-file.js +118 -0
  17. package/dist/client/adp/quick-actions/common/add-new-annotation-file.ts +141 -0
  18. package/dist/client/adp/quick-actions/common/create-page-action.js +50 -50
  19. package/dist/client/adp/quick-actions/common/op-add-custom-section.js +36 -36
  20. package/dist/client/adp/quick-actions/common/op-add-header-field.js +48 -48
  21. package/dist/client/adp/quick-actions/common/utils.js +18 -18
  22. package/dist/client/adp/quick-actions/control-types.js +21 -21
  23. package/dist/client/adp/quick-actions/dialog-enablement-validator.js +24 -24
  24. package/dist/client/adp/quick-actions/enablement-validator.js +4 -4
  25. package/dist/client/adp/quick-actions/fe-v2/change-table-columns.js +101 -101
  26. package/dist/client/adp/quick-actions/fe-v2/create-table-action.js +70 -70
  27. package/dist/client/adp/quick-actions/fe-v2/create-table-custom-column.js +96 -96
  28. package/dist/client/adp/quick-actions/fe-v2/lr-enable-semantic-date-range-filter-bar.js +60 -60
  29. package/dist/client/adp/quick-actions/fe-v2/lr-enable-table-filtering.js +77 -77
  30. package/dist/client/adp/quick-actions/fe-v2/lr-toggle-clear-filter-bar.js +57 -57
  31. package/dist/client/adp/quick-actions/fe-v2/op-enable-empty-row-mode.js +93 -93
  32. package/dist/client/adp/quick-actions/fe-v2/registry.js +73 -72
  33. package/dist/client/adp/quick-actions/fe-v2/registry.ts +5 -2
  34. package/dist/client/adp/quick-actions/fe-v2/utils.js +95 -95
  35. package/dist/client/adp/quick-actions/fe-v4/change-table-columns.js +49 -49
  36. package/dist/client/adp/quick-actions/fe-v4/create-table-action.js +47 -47
  37. package/dist/client/adp/quick-actions/fe-v4/create-table-custom-column.js +46 -46
  38. package/dist/client/adp/quick-actions/fe-v4/lr-enable-semantic-date-range-filter-bar.js +55 -55
  39. package/dist/client/adp/quick-actions/fe-v4/lr-enable-table-filtering.js +82 -82
  40. package/dist/client/adp/quick-actions/fe-v4/lr-toggle-clear-filter-bar.js +52 -52
  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 +57 -56
  43. package/dist/client/adp/quick-actions/fe-v4/registry.ts +5 -2
  44. package/dist/client/adp/quick-actions/fe-v4/utils.js +47 -47
  45. package/dist/client/adp/quick-actions/load.js +44 -44
  46. package/dist/client/adp/quick-actions/quick-action-base.js +53 -53
  47. package/dist/client/adp/ui/FileExistsDialog.fragment.xml +33 -0
  48. package/dist/client/adp/utils.js +160 -160
  49. package/dist/client/cpe/changes/index.js +10 -10
  50. package/dist/client/cpe/changes/service.js +8 -3
  51. package/dist/client/cpe/changes/service.ts +14 -3
  52. package/dist/client/cpe/changes/validator.js +34 -34
  53. package/dist/client/cpe/documentation.js +164 -164
  54. package/dist/client/cpe/feature-service.js +36 -36
  55. package/dist/client/cpe/logger.js +30 -30
  56. package/dist/client/cpe/outline/editable.js +37 -37
  57. package/dist/client/cpe/outline/nodes.js +222 -217
  58. package/dist/client/cpe/outline/nodes.ts +64 -58
  59. package/dist/client/cpe/quick-actions/quick-action-definition.js +4 -4
  60. package/dist/client/cpe/quick-actions/registry.js +143 -143
  61. package/dist/client/cpe/quick-actions/utils.js +92 -92
  62. package/dist/client/cpe/types.js +4 -4
  63. package/dist/client/cpe/ui5-utils.js +33 -33
  64. package/dist/client/cpe/utils.js +138 -138
  65. package/dist/client/flp/WorkspaceConnector.js +86 -86
  66. package/dist/client/flp/common.js +28 -28
  67. package/dist/client/flp/enableFakeConnector.js +83 -83
  68. package/dist/client/flp/initConnectors.js +30 -30
  69. package/dist/client/flp/initRta.js +178 -178
  70. package/dist/client/i18n.js +56 -56
  71. package/dist/client/messagebundle.properties +9 -0
  72. package/dist/client/tsconfig.tsbuildinfo +1 -0
  73. package/dist/client/utils/application.js +32 -32
  74. package/dist/client/utils/core.js +68 -68
  75. package/dist/client/utils/error.js +19 -19
  76. package/dist/client/utils/fe-v4.js +118 -118
  77. package/dist/client/utils/version.js +102 -102
  78. package/package.json +4 -4
@@ -1,115 +1,124 @@
1
- "use strict";
2
-
3
- sap.ui.define(["sap/ui/core/Fragment", "../i18n", "./controllers/AddFragment.controller", "./controllers/AddTableColumnFragments.controller", "./controllers/ControllerExtension.controller", "./controllers/ExtensionPoint.controller"], function (Fragment, ___i18n, __AddFragment, __AddTableColumnFragments, __ControllerExtension, __ExtensionPoint) {
4
- "use strict";
5
-
6
- function _interopRequireDefault(obj) {
7
- return obj && obj.__esModule && typeof obj.default !== "undefined" ? obj.default : obj;
8
- }
9
- const getTextBundle = ___i18n["getTextBundle"];
10
- const AddFragment = _interopRequireDefault(__AddFragment);
11
- const AddTableColumnFragments = _interopRequireDefault(__AddTableColumnFragments);
12
- const ControllerExtension = _interopRequireDefault(__ControllerExtension);
13
- const ExtensionPoint = _interopRequireDefault(__ExtensionPoint);
14
- var DialogNames = /*#__PURE__*/function (DialogNames) {
15
- DialogNames["ADD_FRAGMENT"] = "AddFragment";
16
- DialogNames["ADD_TABLE_COLUMN_FRAGMENTS"] = "AddTableColumnFragments";
17
- DialogNames["CONTROLLER_EXTENSION"] = "ControllerExtension";
18
- DialogNames["ADD_FRAGMENT_AT_EXTENSION_POINT"] = "ExtensionPoint";
19
- return DialogNames;
20
- }(DialogNames || {});
21
- const OPEN_DIALOG_STATUS_CHANGED = 'OPEN_DIALOG_STATUS_CHANGED';
22
- class DialogFactory {
23
- static eventTarget = new EventTarget();
24
- static isDialogOpen = false;
25
- /**
26
- * Only one dialog can be open at a time. This flag indicates if a new dialog can be opened.
27
- */
28
-
29
- static get canOpenDialog() {
30
- return !this.isDialogOpen;
31
- }
32
-
33
- /**
34
- * Factory method for creating a new dialog.
35
- *
36
- * @param overlay - Control overlay.
37
- * @param rta - Runtime Authoring instance.
38
- * @param dialogName - Dialog name.
39
- * @param extensionPointData - Control ID.
40
- * @param options - Dialog options.
41
- */
42
- static async createDialog(overlay, rta, dialogName, extensionPointData) {
43
- let options = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : {};
44
- if (this.isDialogOpen) {
45
- return;
46
- }
47
- let controller;
48
- const resources = await getTextBundle();
49
- switch (dialogName) {
50
- case DialogNames.ADD_FRAGMENT:
51
- controller = new AddFragment(`open.ux.preview.client.adp.controllers.${dialogName}`, overlay, rta, {
52
- aggregation: options.aggregation,
53
- title: resources.getText(options.title ?? 'ADP_ADD_FRAGMENT_DIALOG_TITLE')
54
- });
55
- break;
56
- case DialogNames.ADD_TABLE_COLUMN_FRAGMENTS:
57
- controller = new AddTableColumnFragments(`open.ux.preview.client.adp.controllers.${dialogName}`, overlay, rta, {
58
- aggregation: options.aggregation,
59
- title: resources.getText(options.title ?? 'ADP_ADD_FRAGMENT_DIALOG_TITLE')
60
- });
61
- break;
62
- case DialogNames.CONTROLLER_EXTENSION:
63
- controller = new ControllerExtension(`open.ux.preview.client.adp.controllers.${dialogName}`, overlay, rta);
64
- break;
65
- case DialogNames.ADD_FRAGMENT_AT_EXTENSION_POINT:
66
- controller = new ExtensionPoint(`open.ux.preview.client.adp.controllers.${dialogName}`, overlay, rta, extensionPointData);
67
- break;
68
- }
69
- const id = dialogName === DialogNames.ADD_FRAGMENT_AT_EXTENSION_POINT ? `dialog--${dialogName}` : undefined;
70
- const dialog = await Fragment.load({
71
- name: `open.ux.preview.client.adp.ui.${dialogName}`,
72
- controller,
73
- id
74
- });
75
- this.isDialogOpen = true;
76
- dialog.attachBeforeClose(() => {
77
- this.updateStatus(false);
78
- });
79
- await controller.setup(dialog);
80
- this.updateStatus(true);
81
- }
82
-
83
- /**
84
- * Updates open dialog status.
85
- *
86
- * @param isDialogOpen Flag indicating if there is an open dialog.
87
- */
88
- static updateStatus(isDialogOpen) {
89
- this.isDialogOpen = isDialogOpen;
90
- const event = new CustomEvent(OPEN_DIALOG_STATUS_CHANGED);
91
- this.eventTarget.dispatchEvent(event);
92
- }
93
-
94
- /**
95
- * Attach event handler for OPEN_DIALOG_STATUS_CHANGED event.
96
- *
97
- * @param handler Event handler.
98
- * @returns Function that removes listener.
99
- */
100
- static onOpenDialogStatusChange(handler) {
101
- this.eventTarget.addEventListener(OPEN_DIALOG_STATUS_CHANGED, handler);
102
- return () => {
103
- this.eventTarget.removeEventListener(OPEN_DIALOG_STATUS_CHANGED, handler);
104
- };
105
- }
106
- }
107
- var __exports = {
108
- __esModule: true
109
- };
110
- __exports.DialogNames = DialogNames;
111
- __exports.OPEN_DIALOG_STATUS_CHANGED = OPEN_DIALOG_STATUS_CHANGED;
112
- __exports.DialogFactory = DialogFactory;
113
- return __exports;
1
+ "use strict";
2
+
3
+ sap.ui.define(["sap/ui/core/Fragment", "../i18n", "./controllers/AddFragment.controller", "./controllers/AddTableColumnFragments.controller", "./controllers/ControllerExtension.controller", "./controllers/ExtensionPoint.controller", "./controllers/FileExistsDialog.controller"], function (Fragment, ___i18n, __AddFragment, __AddTableColumnFragments, __ControllerExtension, __ExtensionPoint, __FileExistsDialog) {
4
+ "use strict";
5
+
6
+ function _interopRequireDefault(obj) {
7
+ return obj && obj.__esModule && typeof obj.default !== "undefined" ? obj.default : obj;
8
+ }
9
+ const getTextBundle = ___i18n["getTextBundle"];
10
+ const AddFragment = _interopRequireDefault(__AddFragment);
11
+ const AddTableColumnFragments = _interopRequireDefault(__AddTableColumnFragments);
12
+ const ControllerExtension = _interopRequireDefault(__ControllerExtension);
13
+ const ExtensionPoint = _interopRequireDefault(__ExtensionPoint);
14
+ const FileExistsDialog = _interopRequireDefault(__FileExistsDialog);
15
+ var DialogNames = /*#__PURE__*/function (DialogNames) {
16
+ DialogNames["ADD_FRAGMENT"] = "AddFragment";
17
+ DialogNames["ADD_TABLE_COLUMN_FRAGMENTS"] = "AddTableColumnFragments";
18
+ DialogNames["CONTROLLER_EXTENSION"] = "ControllerExtension";
19
+ DialogNames["ADD_FRAGMENT_AT_EXTENSION_POINT"] = "ExtensionPoint";
20
+ DialogNames["FILE_EXISTS"] = "FileExistsDialog";
21
+ return DialogNames;
22
+ }(DialogNames || {});
23
+ const OPEN_DIALOG_STATUS_CHANGED = 'OPEN_DIALOG_STATUS_CHANGED';
24
+ class DialogFactory {
25
+ static eventTarget = new EventTarget();
26
+ static isDialogOpen = false;
27
+ /**
28
+ * Only one dialog can be open at a time. This flag indicates if a new dialog can be opened.
29
+ */
30
+
31
+ static get canOpenDialog() {
32
+ return !this.isDialogOpen;
33
+ }
34
+
35
+ /**
36
+ * Factory method for creating a new dialog.
37
+ *
38
+ * @param overlay - Control overlay.
39
+ * @param rta - Runtime Authoring instance.
40
+ * @param dialogName - Dialog name.
41
+ * @param extensionPointData - Control ID.
42
+ * @param options - Dialog options.
43
+ */
44
+ static async createDialog(overlay, rta, dialogName, extensionPointData) {
45
+ let options = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : {};
46
+ if (this.isDialogOpen) {
47
+ return;
48
+ }
49
+ let controller;
50
+ const resources = await getTextBundle();
51
+ switch (dialogName) {
52
+ case DialogNames.ADD_FRAGMENT:
53
+ controller = new AddFragment(`open.ux.preview.client.adp.controllers.${dialogName}`, overlay, rta, {
54
+ ...('aggregation' in options && {
55
+ aggregation: options.aggregation
56
+ }),
57
+ title: resources.getText(options.title ?? 'ADP_ADD_FRAGMENT_DIALOG_TITLE')
58
+ });
59
+ break;
60
+ case DialogNames.ADD_TABLE_COLUMN_FRAGMENTS:
61
+ controller = new AddTableColumnFragments(`open.ux.preview.client.adp.controllers.${dialogName}`, overlay, rta, {
62
+ ...('aggregation' in options && {
63
+ aggregation: options.aggregation
64
+ }),
65
+ title: resources.getText(options.title ?? 'ADP_ADD_FRAGMENT_DIALOG_TITLE')
66
+ });
67
+ break;
68
+ case DialogNames.CONTROLLER_EXTENSION:
69
+ controller = new ControllerExtension(`open.ux.preview.client.adp.controllers.${dialogName}`, overlay, rta);
70
+ break;
71
+ case DialogNames.ADD_FRAGMENT_AT_EXTENSION_POINT:
72
+ controller = new ExtensionPoint(`open.ux.preview.client.adp.controllers.${dialogName}`, overlay, rta, extensionPointData);
73
+ break;
74
+ case DialogNames.FILE_EXISTS:
75
+ controller = new FileExistsDialog(`open.ux.preview.client.adp.controllers.${dialogName}`, options);
76
+ break;
77
+ }
78
+ const id = dialogName === DialogNames.ADD_FRAGMENT_AT_EXTENSION_POINT ? `dialog--${dialogName}` : undefined;
79
+ const dialog = await Fragment.load({
80
+ name: `open.ux.preview.client.adp.ui.${dialogName}`,
81
+ controller,
82
+ id
83
+ });
84
+ this.isDialogOpen = true;
85
+ dialog.attachBeforeClose(() => {
86
+ this.updateStatus(false);
87
+ });
88
+ await controller.setup(dialog);
89
+ this.updateStatus(true);
90
+ }
91
+
92
+ /**
93
+ * Updates open dialog status.
94
+ *
95
+ * @param isDialogOpen Flag indicating if there is an open dialog.
96
+ */
97
+ static updateStatus(isDialogOpen) {
98
+ this.isDialogOpen = isDialogOpen;
99
+ const event = new CustomEvent(OPEN_DIALOG_STATUS_CHANGED);
100
+ this.eventTarget.dispatchEvent(event);
101
+ }
102
+
103
+ /**
104
+ * Attach event handler for OPEN_DIALOG_STATUS_CHANGED event.
105
+ *
106
+ * @param handler Event handler.
107
+ * @returns Function that removes listener.
108
+ */
109
+ static onOpenDialogStatusChange(handler) {
110
+ this.eventTarget.addEventListener(OPEN_DIALOG_STATUS_CHANGED, handler);
111
+ return () => {
112
+ this.eventTarget.removeEventListener(OPEN_DIALOG_STATUS_CHANGED, handler);
113
+ };
114
+ }
115
+ }
116
+ var __exports = {
117
+ __esModule: true
118
+ };
119
+ __exports.DialogNames = DialogNames;
120
+ __exports.OPEN_DIALOG_STATUS_CHANGED = OPEN_DIALOG_STATUS_CHANGED;
121
+ __exports.DialogFactory = DialogFactory;
122
+ return __exports;
114
123
  });
115
124
  //# sourceMappingURL=dialog-factory.js.map
@@ -11,15 +11,17 @@ import ControllerExtension from './controllers/ControllerExtension.controller';
11
11
  import ExtensionPoint from './controllers/ExtensionPoint.controller';
12
12
 
13
13
  import { ExtensionPointData } from './extension-point';
14
+ import FileExistsDialog, { FileExistsDialogOptions } from './controllers/FileExistsDialog.controller';
14
15
 
15
16
  export const enum DialogNames {
16
17
  ADD_FRAGMENT = 'AddFragment',
17
18
  ADD_TABLE_COLUMN_FRAGMENTS = 'AddTableColumnFragments',
18
19
  CONTROLLER_EXTENSION = 'ControllerExtension',
19
- ADD_FRAGMENT_AT_EXTENSION_POINT = 'ExtensionPoint'
20
+ ADD_FRAGMENT_AT_EXTENSION_POINT = 'ExtensionPoint',
21
+ FILE_EXISTS = 'FileExistsDialog'
20
22
  }
21
23
 
22
- type Controller = AddFragment | AddTableColumnFragments | ControllerExtension | ExtensionPoint;
24
+ type Controller = AddFragment | AddTableColumnFragments | ControllerExtension | ExtensionPoint | FileExistsDialog;
23
25
 
24
26
  export const OPEN_DIALOG_STATUS_CHANGED = 'OPEN_DIALOG_STATUS_CHANGED';
25
27
 
@@ -48,7 +50,7 @@ export class DialogFactory {
48
50
  rta: RuntimeAuthoring,
49
51
  dialogName: DialogNames,
50
52
  extensionPointData?: ExtensionPointData,
51
- options: Partial<AddFragmentOptions> = {}
53
+ options: Partial<AddFragmentOptions> | Partial<FileExistsDialogOptions> = {}
52
54
  ): Promise<void> {
53
55
  if (this.isDialogOpen) {
54
56
  return;
@@ -59,7 +61,7 @@ export class DialogFactory {
59
61
  switch (dialogName) {
60
62
  case DialogNames.ADD_FRAGMENT:
61
63
  controller = new AddFragment(`open.ux.preview.client.adp.controllers.${dialogName}`, overlay, rta, {
62
- aggregation: options.aggregation,
64
+ ...('aggregation' in options && { aggregation: options.aggregation }),
63
65
  title: resources.getText(options.title ?? 'ADP_ADD_FRAGMENT_DIALOG_TITLE')
64
66
  });
65
67
  break;
@@ -69,7 +71,7 @@ export class DialogFactory {
69
71
  overlay,
70
72
  rta,
71
73
  {
72
- aggregation: options.aggregation,
74
+ ...('aggregation' in options && { aggregation: options.aggregation }),
73
75
  title: resources.getText(options.title ?? 'ADP_ADD_FRAGMENT_DIALOG_TITLE')
74
76
  }
75
77
  );
@@ -89,6 +91,12 @@ export class DialogFactory {
89
91
  extensionPointData!
90
92
  );
91
93
  break;
94
+ case DialogNames.FILE_EXISTS:
95
+ controller = new FileExistsDialog(
96
+ `open.ux.preview.client.adp.controllers.${dialogName}`,
97
+ options as FileExistsDialogOptions
98
+ );
99
+ break;
92
100
  }
93
101
 
94
102
  const id = dialogName === DialogNames.ADD_FRAGMENT_AT_EXTENSION_POINT ? `dialog--${dialogName}` : undefined;
@@ -110,7 +118,7 @@ export class DialogFactory {
110
118
 
111
119
  /**
112
120
  * Updates open dialog status.
113
- *
121
+ *
114
122
  * @param isDialogOpen Flag indicating if there is an open dialog.
115
123
  */
116
124
  private static updateStatus(isDialogOpen: boolean) {
@@ -121,7 +129,7 @@ export class DialogFactory {
121
129
 
122
130
  /**
123
131
  * Attach event handler for OPEN_DIALOG_STATUS_CHANGED event.
124
- *
132
+ *
125
133
  * @param handler Event handler.
126
134
  * @returns Function that removes listener.
127
135
  */
@@ -1,102 +1,102 @@
1
- "use strict";
2
-
3
- sap.ui.define(["sap/ui/rta/util/hasStableId", "sap/ui/fl/Utils", "../cpe/utils", "./dialog-factory"], function (hasStableId, FlUtils, ___cpe_utils, ___dialog_factory) {
4
- "use strict";
5
-
6
- const isReuseComponent = ___cpe_utils["isReuseComponent"];
7
- const DialogFactory = ___dialog_factory["DialogFactory"];
8
- const DialogNames = ___dialog_factory["DialogNames"];
9
- /**
10
- * Handler for enablement of Extend With Controller context menu entry
11
- *
12
- * @param control UI5 control.
13
- * @param syncViewsIds Runtime Authoring
14
- * @param ui5VersionInfo UI5 version information
15
- *
16
- * @returns boolean whether menu item is enabled or not
17
- */
18
- function isControllerExtensionEnabledForControl(control, syncViewsIds, ui5VersionInfo) {
19
- const clickedControlId = FlUtils.getViewForControl(control).getId();
20
- const isClickedControlReuseComponent = isReuseComponent(clickedControlId, ui5VersionInfo);
21
- return !syncViewsIds.includes(clickedControlId) && !isClickedControlReuseComponent;
22
- }
23
-
24
- /**
25
- * Handler for enablement of Extend With Controller context menu entry
26
- *
27
- * @param overlays Control overlays
28
- * @param syncViewsIds Runtime Authoring
29
- * @param ui5VersionInfo UI5 version information
30
- *
31
- * @returns boolean whether menu item is enabled or not
32
- */
33
- const isControllerExtensionEnabled = (overlays, syncViewsIds, ui5VersionInfo) => {
34
- if (overlays.length === 0 || overlays.length > 1) {
35
- return false;
36
- }
37
- return isControllerExtensionEnabledForControl(overlays[0].getElement(), syncViewsIds, ui5VersionInfo);
38
- };
39
-
40
- /**
41
- * Determines whether the fragment command should be enabled based on the provided overlays.
42
- *
43
- * @param {ElementOverlay[]} overlays - An array of ElementOverlay objects representing the UI overlays.
44
- * @param ui5VersionInfo UI5 version information
45
- * @returns {boolean} True if the fragment command is enabled, false otherwise.
46
- */
47
- const isFragmentCommandEnabled = (overlays, ui5VersionInfo) => {
48
- if (overlays.length === 0 || overlays.length > 1) {
49
- return false;
50
- }
51
- const control = overlays[0].getElement();
52
- return hasStableId(overlays[0]) && !isReuseComponent(control.getId(), ui5VersionInfo);
53
- };
54
-
55
- /**
56
- * Determines the text that should be displayed for the Add Fragment context menu item.
57
- *
58
- * @param {ElementOverlay} overlay - An ElementOverlay object representing the UI overlay.
59
- * @returns {string} The text of the Add Fragment context menu item.
60
- */
61
- const getAddFragmentItemText = overlay => {
62
- if (!hasStableId(overlay)) {
63
- return 'Add: Fragment (Unavailable due to unstable ID of the control or its parent control)';
64
- }
65
- return 'Add: Fragment';
66
- };
67
-
68
- /**
69
- * Adds a new item to the context menu
70
- *
71
- * @param rta Runtime Authoring
72
- * @param syncViewsIds Ids of all application sync views
73
- * @param ui5VersionInfo UI5 version information
74
- */
75
- const initDialogs = (rta, syncViewsIds, ui5VersionInfo) => {
76
- const contextMenu = rta.getDefaultPlugins().contextMenu;
77
- contextMenu.addMenuItem({
78
- id: 'ADD_FRAGMENT',
79
- text: getAddFragmentItemText,
80
- handler: async overlays => await DialogFactory.createDialog(overlays[0], rta, DialogNames.ADD_FRAGMENT),
81
- icon: 'sap-icon://attachment-html',
82
- enabled: overlays => isFragmentCommandEnabled(overlays, ui5VersionInfo)
83
- });
84
- contextMenu.addMenuItem({
85
- id: 'EXTEND_CONTROLLER',
86
- text: 'Extend With Controller',
87
- handler: async overlays => await DialogFactory.createDialog(overlays[0], rta, DialogNames.CONTROLLER_EXTENSION),
88
- icon: 'sap-icon://create-form',
89
- enabled: overlays => isControllerExtensionEnabled(overlays, syncViewsIds, ui5VersionInfo)
90
- });
91
- };
92
- var __exports = {
93
- __esModule: true
94
- };
95
- __exports.isControllerExtensionEnabledForControl = isControllerExtensionEnabledForControl;
96
- __exports.isControllerExtensionEnabled = isControllerExtensionEnabled;
97
- __exports.isFragmentCommandEnabled = isFragmentCommandEnabled;
98
- __exports.getAddFragmentItemText = getAddFragmentItemText;
99
- __exports.initDialogs = initDialogs;
100
- return __exports;
1
+ "use strict";
2
+
3
+ sap.ui.define(["sap/ui/rta/util/hasStableId", "sap/ui/fl/Utils", "../cpe/utils", "./dialog-factory"], function (hasStableId, FlUtils, ___cpe_utils, ___dialog_factory) {
4
+ "use strict";
5
+
6
+ const isReuseComponent = ___cpe_utils["isReuseComponent"];
7
+ const DialogFactory = ___dialog_factory["DialogFactory"];
8
+ const DialogNames = ___dialog_factory["DialogNames"];
9
+ /**
10
+ * Handler for enablement of Extend With Controller context menu entry
11
+ *
12
+ * @param control UI5 control.
13
+ * @param syncViewsIds Runtime Authoring
14
+ * @param ui5VersionInfo UI5 version information
15
+ *
16
+ * @returns boolean whether menu item is enabled or not
17
+ */
18
+ function isControllerExtensionEnabledForControl(control, syncViewsIds, ui5VersionInfo) {
19
+ const clickedControlId = FlUtils.getViewForControl(control).getId();
20
+ const isClickedControlReuseComponent = isReuseComponent(clickedControlId, ui5VersionInfo);
21
+ return !syncViewsIds.includes(clickedControlId) && !isClickedControlReuseComponent;
22
+ }
23
+
24
+ /**
25
+ * Handler for enablement of Extend With Controller context menu entry
26
+ *
27
+ * @param overlays Control overlays
28
+ * @param syncViewsIds Runtime Authoring
29
+ * @param ui5VersionInfo UI5 version information
30
+ *
31
+ * @returns boolean whether menu item is enabled or not
32
+ */
33
+ const isControllerExtensionEnabled = (overlays, syncViewsIds, ui5VersionInfo) => {
34
+ if (overlays.length === 0 || overlays.length > 1) {
35
+ return false;
36
+ }
37
+ return isControllerExtensionEnabledForControl(overlays[0].getElement(), syncViewsIds, ui5VersionInfo);
38
+ };
39
+
40
+ /**
41
+ * Determines whether the fragment command should be enabled based on the provided overlays.
42
+ *
43
+ * @param {ElementOverlay[]} overlays - An array of ElementOverlay objects representing the UI overlays.
44
+ * @param ui5VersionInfo UI5 version information
45
+ * @returns {boolean} True if the fragment command is enabled, false otherwise.
46
+ */
47
+ const isFragmentCommandEnabled = (overlays, ui5VersionInfo) => {
48
+ if (overlays.length === 0 || overlays.length > 1) {
49
+ return false;
50
+ }
51
+ const control = overlays[0].getElement();
52
+ return hasStableId(overlays[0]) && !isReuseComponent(control.getId(), ui5VersionInfo);
53
+ };
54
+
55
+ /**
56
+ * Determines the text that should be displayed for the Add Fragment context menu item.
57
+ *
58
+ * @param {ElementOverlay} overlay - An ElementOverlay object representing the UI overlay.
59
+ * @returns {string} The text of the Add Fragment context menu item.
60
+ */
61
+ const getAddFragmentItemText = overlay => {
62
+ if (!hasStableId(overlay)) {
63
+ return 'Add: Fragment (Unavailable due to unstable ID of the control or its parent control)';
64
+ }
65
+ return 'Add: Fragment';
66
+ };
67
+
68
+ /**
69
+ * Adds a new item to the context menu
70
+ *
71
+ * @param rta Runtime Authoring
72
+ * @param syncViewsIds Ids of all application sync views
73
+ * @param ui5VersionInfo UI5 version information
74
+ */
75
+ const initDialogs = (rta, syncViewsIds, ui5VersionInfo) => {
76
+ const contextMenu = rta.getDefaultPlugins().contextMenu;
77
+ contextMenu.addMenuItem({
78
+ id: 'ADD_FRAGMENT',
79
+ text: getAddFragmentItemText,
80
+ handler: async overlays => await DialogFactory.createDialog(overlays[0], rta, DialogNames.ADD_FRAGMENT),
81
+ icon: 'sap-icon://attachment-html',
82
+ enabled: overlays => isFragmentCommandEnabled(overlays, ui5VersionInfo)
83
+ });
84
+ contextMenu.addMenuItem({
85
+ id: 'EXTEND_CONTROLLER',
86
+ text: 'Extend With Controller',
87
+ handler: async overlays => await DialogFactory.createDialog(overlays[0], rta, DialogNames.CONTROLLER_EXTENSION),
88
+ icon: 'sap-icon://create-form',
89
+ enabled: overlays => isControllerExtensionEnabled(overlays, syncViewsIds, ui5VersionInfo)
90
+ });
91
+ };
92
+ var __exports = {
93
+ __esModule: true
94
+ };
95
+ __exports.isControllerExtensionEnabledForControl = isControllerExtensionEnabledForControl;
96
+ __exports.isControllerExtensionEnabled = isControllerExtensionEnabled;
97
+ __exports.isFragmentCommandEnabled = isFragmentCommandEnabled;
98
+ __exports.getAddFragmentItemText = getAddFragmentItemText;
99
+ __exports.initDialogs = initDialogs;
100
+ return __exports;
101
101
  });
102
102
  //# sourceMappingURL=init-dialogs.js.map
@@ -1,57 +1,57 @@
1
- "use strict";
2
-
3
- sap.ui.define(["sap/ui/dt/OverlayRegistry", "../../../utils/version", "../../utils", "../../../cpe/quick-actions/utils", "../../dialog-factory", "../../init-dialogs", "../../api-handler", "../simple-quick-action-base", "../dialog-enablement-validator"], function (OverlayRegistry, _____utils_version, ____utils, _____cpe_quick_actions_utils, ____dialog_factory, ____init_dialogs, ____api_handler, ___simple_quick_action_base, ___dialog_enablement_validator) {
4
- "use strict";
5
-
6
- const getUi5Version = _____utils_version["getUi5Version"];
7
- const getAllSyncViewsIds = ____utils["getAllSyncViewsIds"];
8
- const getControllerInfoForControl = ____utils["getControllerInfoForControl"];
9
- const getRelevantControlFromActivePage = _____cpe_quick_actions_utils["getRelevantControlFromActivePage"];
10
- const DialogFactory = ____dialog_factory["DialogFactory"];
11
- const DialogNames = ____dialog_factory["DialogNames"];
12
- const isControllerExtensionEnabledForControl = ____init_dialogs["isControllerExtensionEnabledForControl"];
13
- const getExistingController = ____api_handler["getExistingController"];
14
- const SimpleQuickActionDefinitionBase = ___simple_quick_action_base["SimpleQuickActionDefinitionBase"];
15
- const DIALOG_ENABLEMENT_VALIDATOR = ___dialog_enablement_validator["DIALOG_ENABLEMENT_VALIDATOR"];
16
- const ADD_CONTROLLER_TO_PAGE_TYPE = 'add-controller-to-page';
17
- const CONTROL_TYPES = ['sap.f.DynamicPage', 'sap.uxap.ObjectPageLayout'];
18
-
19
- /**
20
- * Quick Action for adding controller to a page.
21
- */
22
- class AddControllerToPageQuickAction extends SimpleQuickActionDefinitionBase {
23
- constructor(context) {
24
- super(ADD_CONTROLLER_TO_PAGE_TYPE, CONTROL_TYPES, '', context, [DIALOG_ENABLEMENT_VALIDATOR]);
25
- }
26
- controllerExists = false;
27
- async initialize() {
28
- for (const control of getRelevantControlFromActivePage(this.context.controlIndex, this.context.view, CONTROL_TYPES)) {
29
- const version = await getUi5Version();
30
- const syncViewsIds = await getAllSyncViewsIds(version);
31
- const controlInfo = getControllerInfoForControl(control);
32
- const data = await getExistingController(controlInfo.controllerName);
33
- this.controllerExists = data?.controllerExists;
34
- const isActiveAction = isControllerExtensionEnabledForControl(control, syncViewsIds, version);
35
- this.control = isActiveAction ? control : undefined;
36
- break;
37
- }
38
- }
39
- get textKey() {
40
- return this.controllerExists ? 'QUICK_ACTION_SHOW_PAGE_CONTROLLER' : 'QUICK_ACTION_ADD_PAGE_CONTROLLER';
41
- }
42
- async execute() {
43
- if (this.control) {
44
- const overlay = OverlayRegistry.getOverlay(this.control) || [];
45
- await DialogFactory.createDialog(overlay, this.context.rta, DialogNames.CONTROLLER_EXTENSION);
46
- }
47
- return [];
48
- }
49
- }
50
- var __exports = {
51
- __esModule: true
52
- };
53
- __exports.ADD_CONTROLLER_TO_PAGE_TYPE = ADD_CONTROLLER_TO_PAGE_TYPE;
54
- __exports.AddControllerToPageQuickAction = AddControllerToPageQuickAction;
55
- return __exports;
1
+ "use strict";
2
+
3
+ sap.ui.define(["sap/ui/dt/OverlayRegistry", "../../../utils/version", "../../utils", "../../../cpe/quick-actions/utils", "../../dialog-factory", "../../init-dialogs", "../../api-handler", "../simple-quick-action-base", "../dialog-enablement-validator"], function (OverlayRegistry, _____utils_version, ____utils, _____cpe_quick_actions_utils, ____dialog_factory, ____init_dialogs, ____api_handler, ___simple_quick_action_base, ___dialog_enablement_validator) {
4
+ "use strict";
5
+
6
+ const getUi5Version = _____utils_version["getUi5Version"];
7
+ const getAllSyncViewsIds = ____utils["getAllSyncViewsIds"];
8
+ const getControllerInfoForControl = ____utils["getControllerInfoForControl"];
9
+ const getRelevantControlFromActivePage = _____cpe_quick_actions_utils["getRelevantControlFromActivePage"];
10
+ const DialogFactory = ____dialog_factory["DialogFactory"];
11
+ const DialogNames = ____dialog_factory["DialogNames"];
12
+ const isControllerExtensionEnabledForControl = ____init_dialogs["isControllerExtensionEnabledForControl"];
13
+ const getExistingController = ____api_handler["getExistingController"];
14
+ const SimpleQuickActionDefinitionBase = ___simple_quick_action_base["SimpleQuickActionDefinitionBase"];
15
+ const DIALOG_ENABLEMENT_VALIDATOR = ___dialog_enablement_validator["DIALOG_ENABLEMENT_VALIDATOR"];
16
+ const ADD_CONTROLLER_TO_PAGE_TYPE = 'add-controller-to-page';
17
+ const CONTROL_TYPES = ['sap.f.DynamicPage', 'sap.uxap.ObjectPageLayout'];
18
+
19
+ /**
20
+ * Quick Action for adding controller to a page.
21
+ */
22
+ class AddControllerToPageQuickAction extends SimpleQuickActionDefinitionBase {
23
+ constructor(context) {
24
+ super(ADD_CONTROLLER_TO_PAGE_TYPE, CONTROL_TYPES, '', context, [DIALOG_ENABLEMENT_VALIDATOR]);
25
+ }
26
+ controllerExists = false;
27
+ async initialize() {
28
+ for (const control of getRelevantControlFromActivePage(this.context.controlIndex, this.context.view, CONTROL_TYPES)) {
29
+ const version = await getUi5Version();
30
+ const syncViewsIds = await getAllSyncViewsIds(version);
31
+ const controlInfo = getControllerInfoForControl(control);
32
+ const data = await getExistingController(controlInfo.controllerName);
33
+ this.controllerExists = data?.controllerExists;
34
+ const isActiveAction = isControllerExtensionEnabledForControl(control, syncViewsIds, version);
35
+ this.control = isActiveAction ? control : undefined;
36
+ break;
37
+ }
38
+ }
39
+ get textKey() {
40
+ return this.controllerExists ? 'QUICK_ACTION_SHOW_PAGE_CONTROLLER' : 'QUICK_ACTION_ADD_PAGE_CONTROLLER';
41
+ }
42
+ async execute() {
43
+ if (this.control) {
44
+ const overlay = OverlayRegistry.getOverlay(this.control) || [];
45
+ await DialogFactory.createDialog(overlay, this.context.rta, DialogNames.CONTROLLER_EXTENSION);
46
+ }
47
+ return [];
48
+ }
49
+ }
50
+ var __exports = {
51
+ __esModule: true
52
+ };
53
+ __exports.ADD_CONTROLLER_TO_PAGE_TYPE = ADD_CONTROLLER_TO_PAGE_TYPE;
54
+ __exports.AddControllerToPageQuickAction = AddControllerToPageQuickAction;
55
+ return __exports;
56
56
  });
57
57
  //# sourceMappingURL=add-controller-to-page.js.map