@sapui5/sap.fe.controls 1.136.5 → 1.136.7
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 +1 -1
- package/src/sap/fe/controls/.library +1 -1
- package/src/sap/fe/controls/library.js +1 -1
- package/src/sap/fe/controls/shortcuts/ShortcutExplanationProvider.js +38 -2
- package/src/sap/fe/controls/shortcuts/ShortcutExplanationProvider.tsx +37 -1
- package/src/sap/fe/controls/shortcuts/popup/ShortcutTool.js +8 -1
- package/src/sap/fe/controls/shortcuts/popup/ShortcutTool.tsx +5 -0
package/package.json
CHANGED
|
@@ -22,7 +22,7 @@ sap.ui.define(["sap/fe/base/library", "sap/fe/controls/shortcuts/ShortcutExplana
|
|
|
22
22
|
controls: [],
|
|
23
23
|
elements: [],
|
|
24
24
|
// eslint-disable-next-line no-template-curly-in-string
|
|
25
|
-
version: "1.136.
|
|
25
|
+
version: "1.136.7",
|
|
26
26
|
noLibraryCSS: false
|
|
27
27
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
28
28
|
});
|
|
@@ -35,7 +35,8 @@ sap.ui.define(["sap/base/Log", "sap/base/security/encodeURL", "sap/fe/base/Class
|
|
|
35
35
|
if (left + windowWidth > window.screen.availWidth) {
|
|
36
36
|
left = window.screen.availWidth - windowWidth;
|
|
37
37
|
}
|
|
38
|
-
|
|
38
|
+
let theme = Theming.getTheme();
|
|
39
|
+
theme = this._sanitizeTheme(theme);
|
|
39
40
|
const url = sap.ui.require.toUrl("sap/fe/controls/shortcuts/popup/index.html");
|
|
40
41
|
const localOrigin = window.location.protocol + "//" + window.location.host;
|
|
41
42
|
// We pass the theme and the origin to the popup so that it can communicate safely with the parent
|
|
@@ -72,6 +73,41 @@ sap.ui.define(["sap/base/Log", "sap/base/security/encodeURL", "sap/fe/base/Class
|
|
|
72
73
|
myWin.close();
|
|
73
74
|
};
|
|
74
75
|
}
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
/**
|
|
79
|
+
* Sanitizes the theme name to ensure it starts with "sap-".
|
|
80
|
+
* If the theme does not start with "sap-", it tries to get the theme from the computed styles.
|
|
81
|
+
* If it still does not find a valid theme, it defaults to "sap_horizon".
|
|
82
|
+
* This is to ensure that the popup always uses a valid theme.
|
|
83
|
+
* @param theme The theme name to sanitize
|
|
84
|
+
* @returns The sanitized theme name
|
|
85
|
+
* @private
|
|
86
|
+
*/;
|
|
87
|
+
_proto._sanitizeTheme = function _sanitizeTheme(theme) {
|
|
88
|
+
if (!theme.startsWith("sap_")) {
|
|
89
|
+
try {
|
|
90
|
+
const computedStyles = getComputedStyle(document.documentElement);
|
|
91
|
+
theme = computedStyles.getPropertyValue("--sapSapThemeId");
|
|
92
|
+
if (!theme) {
|
|
93
|
+
const themeMetadata = computedStyles.getPropertyValue("--sapThemeMetaData-UI5-sap-ui-core");
|
|
94
|
+
if (themeMetadata) {
|
|
95
|
+
const themeMatch = JSON.parse(themeMetadata);
|
|
96
|
+
if (themeMatch && themeMatch.Extends && themeMatch.Extends.length > 0) {
|
|
97
|
+
theme = themeMatch.Extends[0];
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
} catch (e) {
|
|
102
|
+
Log.info("Cannot get theme from computed styles", e instanceof Error ? e.message : String(e));
|
|
103
|
+
theme = "sap_horizon";
|
|
104
|
+
}
|
|
105
|
+
if (!theme || !theme.startsWith("sap_")) {
|
|
106
|
+
// Final fallback to sap_horizon
|
|
107
|
+
theme = "sap_horizon";
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
return theme;
|
|
75
111
|
};
|
|
76
112
|
/**
|
|
77
113
|
* Creates or returns the instance of the ShortcutExplanationProvider.
|
|
@@ -134,4 +170,4 @@ sap.ui.define(["sap/base/Log", "sap/base/security/encodeURL", "sap/fe/base/Class
|
|
|
134
170
|
_exports = ShortcutExplanationProvider;
|
|
135
171
|
return _exports;
|
|
136
172
|
}, false);
|
|
137
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["ShortcutExplanationProvider","_dec","defineUI5Class","_class","_ShortcutExplanationProvider","_ManagedObject","_this","_len","arguments","length","args","Array","_key","call","_popupIdx","_exports","_inheritsLoose","_proto","prototype","getShellDialogContent","windowWidth","left","window","screenLeft","outerWidth","screen","availWidth","theme","Theming","getTheme","url","sap","ui","require","toUrl","localOrigin","location","protocol","host","params","encodeURL","myWin","open","screenTop","handleMessageReceived","messageEvent","origin","messageData","data","service","messagePort","ports","postMessage","startsWith","removeEventListener","opener","e","Log","debug","Error","message","String","setTimeout","addEventListener","id","onunload","close","getInstance","shellContainer","resolveCreation","instance","instancePromise","Promise","resolve","extensionService","getServiceAsync","shellHistoryProvider","registerUserAction","error","undefined","shellExtensionService","resourceBundle","Lib","getResourceBundleFor","shellHistoryDialog","isDialogAdded","userAction","createUserAction","text","getText","icon","IconPool","getIconURI","press","controlType","showForAllApps","err","ManagedObject"],"sourceRoot":".","sources":["ShortcutExplanationProvider.tsx"],"sourcesContent":["import Log from \"sap/base/Log\";\nimport encodeURL from \"sap/base/security/encodeURL\";\nimport { defineUI5Class } from \"sap/fe/base/ClassSupport\";\nimport ManagedObject from \"sap/ui/base/ManagedObject\";\nimport IconPool from \"sap/ui/core/IconPool\";\nimport Lib from \"sap/ui/core/Lib\";\nimport Theming from \"sap/ui/core/Theming\";\nimport type Container from \"sap/ushell/Container\";\nimport type Extension from \"sap/ushell/services/Extension\";\n\n/**\n * Provides a dialog to explain the shortcuts to the user.\n * This dialog will be registered in the shell user menu and will open as an independent window.\n * @experimental\n */\n@defineUI5Class(\"sap.fe.controls.shortcuts.ShortcutExplanationProvider\")\nexport default class ShortcutExplanationProvider extends ManagedObject {\n\tprivate _popupIdx = 0;\n\n\tgetShellDialogContent(): void {\n\t\t// Position to top right of the main window if possible\n\t\tconst windowWidth = 620;\n\t\tlet left = window.screenLeft + window.outerWidth;\n\t\tif (left + windowWidth > window.screen.availWidth) {\n\t\t\tleft = window.screen.availWidth - windowWidth;\n\t\t}\n\t\tconst theme = Theming.getTheme();\n\t\tconst url = sap.ui.require.toUrl(\"sap/fe/controls/shortcuts/popup/index.html\");\n\t\tconst localOrigin = window.location.protocol + \"//\" + window.location.host;\n\t\t// We pass the theme and the origin to the popup so that it can communicate safely with the parent\n\t\tconst params = \"?sap-ui-xx-shortcut-origin=\" + encodeURL(localOrigin) + \"&sap-ui-theme=\" + theme;\n\t\tconst myWin = window.open(\n\t\t\turl + params,\n\t\t\t\"_blank\",\n\t\t\t`popup,toolbar=no,menubar=no,scrollbars=no,location=no,width=${windowWidth},height=550,top=${window.screenTop},left=${left}`\n\t\t);\n\t\tif (myWin) {\n\t\t\tconst handleMessageReceived = (messageEvent: MessageEvent): void => {\n\t\t\t\tif (localOrigin === messageEvent.origin) {\n\t\t\t\t\tconst messageData = messageEvent?.data;\n\t\t\t\t\tif (messageData.service === \"sap.ui.interaction.MessagePortReady\") {\n\t\t\t\t\t\tconst messagePort = messageEvent.ports[0]; // Remember the port\n\t\t\t\t\t\tmyWin.postMessage({ service: \"sap.ui.interaction.MessagePortReady\" }, url.startsWith(\"/\") ? localOrigin : url, [\n\t\t\t\t\t\t\tmessagePort\n\t\t\t\t\t\t]);\n\t\t\t\t\t\twindow.removeEventListener(\"message\", handleMessageReceived);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t};\n\t\t\ttry {\n\t\t\t\tmyWin.opener = null;\n\t\t\t} catch (e) {\n\t\t\t\t// This might fail when there is CORS involved anyway and we can't access the opener anyway\n\t\t\t\tLog.debug(\"Cannot set opener to null\", e instanceof Error ? e.message : String(e));\n\t\t\t}\n\n\t\t\tsetTimeout((): void => {\n\t\t\t\twindow.addEventListener(\"message\", handleMessageReceived);\n\t\t\t\twindow.postMessage(\n\t\t\t\t\t{ id: \"sap.fe.interaction.Popup\" + this._popupIdx++, service: \"sap.ui.interaction.RequestMessagePort\" },\n\t\t\t\t\tlocalOrigin\n\t\t\t\t);\n\t\t\t}, 1500); // give a bit of time for the popup to be ready\n\t\t\t// We can't rely on the onload of the popup because it is not always availble in CORS scenarios\n\t\t\twindow.onunload = function (): void {\n\t\t\t\tmyWin.close();\n\t\t\t};\n\t\t}\n\t}\n\n\tstatic instancePromise: Promise<ShortcutExplanationProvider | undefined>;\n\n\tstatic instance: ShortcutExplanationProvider | undefined;\n\n\tstatic isDialogAdded = false;\n\n\t/**\n\t * Creates or returns the instance of the ShortcutExplanationProvider.\n\t * This is a singleton to ensure we only have one instance of the dialog.\n\t * @returns The instance of the ShortcutExplanationProvider\n\t */\n\tstatic async getInstance(): Promise<ShortcutExplanationProvider | undefined> {\n\t\t// Test the shell existence and register the extension\n\t\tconst shellContainer = sap.ui.require(\"sap/ushell/Container\") as Container | undefined;\n\t\tlet resolveCreation: Function | undefined;\n\t\ttry {\n\t\t\tif (shellContainer && !this.instance) {\n\t\t\t\tthis.instancePromise = new Promise<ShortcutExplanationProvider | undefined>((resolve) => {\n\t\t\t\t\tresolveCreation = resolve;\n\t\t\t\t});\n\t\t\t\tconst extensionService = (await shellContainer.getServiceAsync(\"Extension\")) as Extension | undefined;\n\t\t\t\tif (extensionService) {\n\t\t\t\t\tconst shellHistoryProvider = await ShortcutExplanationProvider.registerUserAction(extensionService);\n\t\t\t\t\tthis.instance = shellHistoryProvider;\n\t\t\t\t\tresolveCreation!(shellHistoryProvider);\n\t\t\t\t}\n\t\t\t}\n\t\t} catch (e) {\n\t\t\tLog.error(\"Cannot register extension\", e instanceof Error ? e.message : String(e));\n\t\t\tresolveCreation?.(undefined);\n\t\t}\n\t\treturn this.instancePromise;\n\t}\n\n\t/**\n\t * Adds the user action to the shell, the action will open the dialog with the shortcuts.\n\t * @param shellExtensionService The extension service to add the user action to the shell\n\t * @returns The dialog with the shortcuts\n\t */\n\tstatic async registerUserAction(shellExtensionService: Extension): Promise<ShortcutExplanationProvider | undefined> {\n\t\ttry {\n\t\t\tconst resourceBundle = Lib.getResourceBundleFor(\"sap.fe.controls\")!;\n\n\t\t\tconst shellHistoryDialog = new ShortcutExplanationProvider();\n\t\t\tif (!this.isDialogAdded) {\n\t\t\t\tthis.isDialogAdded = true;\n\t\t\t\tconst userAction = await shellExtensionService.createUserAction(\n\t\t\t\t\t{\n\t\t\t\t\t\tid: \"sapui5.shortcut.explanation.trigger\",\n\t\t\t\t\t\ttext: resourceBundle.getText(\"C_SHORTCUT_TITLE\"),\n\t\t\t\t\t\ticon: IconPool.getIconURI(\"keyboard-and-mouse\"),\n\t\t\t\t\t\tpress: (): void => {\n\t\t\t\t\t\t\tshellHistoryDialog.getShellDialogContent();\n\t\t\t\t\t\t}\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tcontrolType: \"sap.m.Button\"\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t\tuserAction.showForAllApps();\n\t\t\t}\n\t\t\treturn shellHistoryDialog;\n\t\t} catch (err) {\n\t\t\tLog.error(\"Cannot add user action\", err instanceof Error ? err.message : String(err));\n\t\t}\n\t}\n}\n"],"mappings":"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","ignoreList":[]}
|
|
173
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["ShortcutExplanationProvider","_dec","defineUI5Class","_class","_ShortcutExplanationProvider","_ManagedObject","_this","_len","arguments","length","args","Array","_key","call","_popupIdx","_exports","_inheritsLoose","_proto","prototype","getShellDialogContent","windowWidth","left","window","screenLeft","outerWidth","screen","availWidth","theme","Theming","getTheme","_sanitizeTheme","url","sap","ui","require","toUrl","localOrigin","location","protocol","host","params","encodeURL","myWin","open","screenTop","handleMessageReceived","messageEvent","origin","messageData","data","service","messagePort","ports","postMessage","startsWith","removeEventListener","opener","e","Log","debug","Error","message","String","setTimeout","addEventListener","id","onunload","close","computedStyles","getComputedStyle","document","documentElement","getPropertyValue","themeMetadata","themeMatch","JSON","parse","Extends","info","getInstance","shellContainer","resolveCreation","instance","instancePromise","Promise","resolve","extensionService","getServiceAsync","shellHistoryProvider","registerUserAction","error","undefined","shellExtensionService","resourceBundle","Lib","getResourceBundleFor","shellHistoryDialog","isDialogAdded","userAction","createUserAction","text","getText","icon","IconPool","getIconURI","press","controlType","showForAllApps","err","ManagedObject"],"sourceRoot":".","sources":["ShortcutExplanationProvider.tsx"],"sourcesContent":["import Log from \"sap/base/Log\";\nimport encodeURL from \"sap/base/security/encodeURL\";\nimport { defineUI5Class } from \"sap/fe/base/ClassSupport\";\nimport ManagedObject from \"sap/ui/base/ManagedObject\";\nimport IconPool from \"sap/ui/core/IconPool\";\nimport Lib from \"sap/ui/core/Lib\";\nimport Theming from \"sap/ui/core/Theming\";\nimport type Container from \"sap/ushell/Container\";\nimport type Extension from \"sap/ushell/services/Extension\";\n\n/**\n * Provides a dialog to explain the shortcuts to the user.\n * This dialog will be registered in the shell user menu and will open as an independent window.\n * @experimental\n */\n@defineUI5Class(\"sap.fe.controls.shortcuts.ShortcutExplanationProvider\")\nexport default class ShortcutExplanationProvider extends ManagedObject {\n\tprivate _popupIdx = 0;\n\n\tgetShellDialogContent(): void {\n\t\t// Position to top right of the main window if possible\n\t\tconst windowWidth = 620;\n\t\tlet left = window.screenLeft + window.outerWidth;\n\t\tif (left + windowWidth > window.screen.availWidth) {\n\t\t\tleft = window.screen.availWidth - windowWidth;\n\t\t}\n\t\tlet theme = Theming.getTheme();\n\t\ttheme = this._sanitizeTheme(theme);\n\t\tconst url = sap.ui.require.toUrl(\"sap/fe/controls/shortcuts/popup/index.html\");\n\t\tconst localOrigin = window.location.protocol + \"//\" + window.location.host;\n\t\t// We pass the theme and the origin to the popup so that it can communicate safely with the parent\n\t\tconst params = \"?sap-ui-xx-shortcut-origin=\" + encodeURL(localOrigin) + \"&sap-ui-theme=\" + theme;\n\t\tconst myWin = window.open(\n\t\t\turl + params,\n\t\t\t\"_blank\",\n\t\t\t`popup,toolbar=no,menubar=no,scrollbars=no,location=no,width=${windowWidth},height=550,top=${window.screenTop},left=${left}`\n\t\t);\n\t\tif (myWin) {\n\t\t\tconst handleMessageReceived = (messageEvent: MessageEvent): void => {\n\t\t\t\tif (localOrigin === messageEvent.origin) {\n\t\t\t\t\tconst messageData = messageEvent?.data;\n\t\t\t\t\tif (messageData.service === \"sap.ui.interaction.MessagePortReady\") {\n\t\t\t\t\t\tconst messagePort = messageEvent.ports[0]; // Remember the port\n\t\t\t\t\t\tmyWin.postMessage({ service: \"sap.ui.interaction.MessagePortReady\" }, url.startsWith(\"/\") ? localOrigin : url, [\n\t\t\t\t\t\t\tmessagePort\n\t\t\t\t\t\t]);\n\t\t\t\t\t\twindow.removeEventListener(\"message\", handleMessageReceived);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t};\n\t\t\ttry {\n\t\t\t\tmyWin.opener = null;\n\t\t\t} catch (e) {\n\t\t\t\t// This might fail when there is CORS involved anyway and we can't access the opener anyway\n\t\t\t\tLog.debug(\"Cannot set opener to null\", e instanceof Error ? e.message : String(e));\n\t\t\t}\n\n\t\t\tsetTimeout((): void => {\n\t\t\t\twindow.addEventListener(\"message\", handleMessageReceived);\n\t\t\t\twindow.postMessage(\n\t\t\t\t\t{ id: \"sap.fe.interaction.Popup\" + this._popupIdx++, service: \"sap.ui.interaction.RequestMessagePort\" },\n\t\t\t\t\tlocalOrigin\n\t\t\t\t);\n\t\t\t}, 1500); // give a bit of time for the popup to be ready\n\t\t\t// We can't rely on the onload of the popup because it is not always availble in CORS scenarios\n\t\t\twindow.onunload = function (): void {\n\t\t\t\tmyWin.close();\n\t\t\t};\n\t\t}\n\t}\n\n\t/**\n\t * Sanitizes the theme name to ensure it starts with \"sap-\".\n\t * If the theme does not start with \"sap-\", it tries to get the theme from the computed styles.\n\t * If it still does not find a valid theme, it defaults to \"sap_horizon\".\n\t * This is to ensure that the popup always uses a valid theme.\n\t * @param theme The theme name to sanitize\n\t * @returns The sanitized theme name\n\t * @private\n\t */\n\tprivate _sanitizeTheme(theme: string): string {\n\t\tif (!theme.startsWith(\"sap_\")) {\n\t\t\ttry {\n\t\t\t\tconst computedStyles = getComputedStyle(document.documentElement);\n\t\t\t\ttheme = computedStyles.getPropertyValue(\"--sapSapThemeId\");\n\t\t\t\tif (!theme) {\n\t\t\t\t\tconst themeMetadata = computedStyles.getPropertyValue(\"--sapThemeMetaData-UI5-sap-ui-core\");\n\t\t\t\t\tif (themeMetadata) {\n\t\t\t\t\t\tconst themeMatch = JSON.parse(themeMetadata);\n\t\t\t\t\t\tif (themeMatch && themeMatch.Extends && themeMatch.Extends.length > 0) {\n\t\t\t\t\t\t\ttheme = themeMatch.Extends[0];\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\tLog.info(\"Cannot get theme from computed styles\", e instanceof Error ? e.message : String(e));\n\t\t\t\ttheme = \"sap_horizon\";\n\t\t\t}\n\t\t\tif (!theme || !theme.startsWith(\"sap_\")) {\n\t\t\t\t// Final fallback to sap_horizon\n\t\t\t\ttheme = \"sap_horizon\";\n\t\t\t}\n\t\t}\n\t\treturn theme;\n\t}\n\n\tstatic instancePromise: Promise<ShortcutExplanationProvider | undefined>;\n\n\tstatic instance: ShortcutExplanationProvider | undefined;\n\n\tstatic isDialogAdded = false;\n\n\t/**\n\t * Creates or returns the instance of the ShortcutExplanationProvider.\n\t * This is a singleton to ensure we only have one instance of the dialog.\n\t * @returns The instance of the ShortcutExplanationProvider\n\t */\n\tstatic async getInstance(): Promise<ShortcutExplanationProvider | undefined> {\n\t\t// Test the shell existence and register the extension\n\t\tconst shellContainer = sap.ui.require(\"sap/ushell/Container\") as Container | undefined;\n\t\tlet resolveCreation: Function | undefined;\n\t\ttry {\n\t\t\tif (shellContainer && !this.instance) {\n\t\t\t\tthis.instancePromise = new Promise<ShortcutExplanationProvider | undefined>((resolve) => {\n\t\t\t\t\tresolveCreation = resolve;\n\t\t\t\t});\n\t\t\t\tconst extensionService = (await shellContainer.getServiceAsync(\"Extension\")) as Extension | undefined;\n\t\t\t\tif (extensionService) {\n\t\t\t\t\tconst shellHistoryProvider = await ShortcutExplanationProvider.registerUserAction(extensionService);\n\t\t\t\t\tthis.instance = shellHistoryProvider;\n\t\t\t\t\tresolveCreation!(shellHistoryProvider);\n\t\t\t\t}\n\t\t\t}\n\t\t} catch (e) {\n\t\t\tLog.error(\"Cannot register extension\", e instanceof Error ? e.message : String(e));\n\t\t\tresolveCreation?.(undefined);\n\t\t}\n\t\treturn this.instancePromise;\n\t}\n\n\t/**\n\t * Adds the user action to the shell, the action will open the dialog with the shortcuts.\n\t * @param shellExtensionService The extension service to add the user action to the shell\n\t * @returns The dialog with the shortcuts\n\t */\n\tstatic async registerUserAction(shellExtensionService: Extension): Promise<ShortcutExplanationProvider | undefined> {\n\t\ttry {\n\t\t\tconst resourceBundle = Lib.getResourceBundleFor(\"sap.fe.controls\")!;\n\n\t\t\tconst shellHistoryDialog = new ShortcutExplanationProvider();\n\t\t\tif (!this.isDialogAdded) {\n\t\t\t\tthis.isDialogAdded = true;\n\t\t\t\tconst userAction = await shellExtensionService.createUserAction(\n\t\t\t\t\t{\n\t\t\t\t\t\tid: \"sapui5.shortcut.explanation.trigger\",\n\t\t\t\t\t\ttext: resourceBundle.getText(\"C_SHORTCUT_TITLE\"),\n\t\t\t\t\t\ticon: IconPool.getIconURI(\"keyboard-and-mouse\"),\n\t\t\t\t\t\tpress: (): void => {\n\t\t\t\t\t\t\tshellHistoryDialog.getShellDialogContent();\n\t\t\t\t\t\t}\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tcontrolType: \"sap.m.Button\"\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t\tuserAction.showForAllApps();\n\t\t\t}\n\t\t\treturn shellHistoryDialog;\n\t\t} catch (err) {\n\t\t\tLog.error(\"Cannot add user action\", err instanceof Error ? err.message : String(err));\n\t\t}\n\t}\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -24,7 +24,8 @@ export default class ShortcutExplanationProvider extends ManagedObject {
|
|
|
24
24
|
if (left + windowWidth > window.screen.availWidth) {
|
|
25
25
|
left = window.screen.availWidth - windowWidth;
|
|
26
26
|
}
|
|
27
|
-
|
|
27
|
+
let theme = Theming.getTheme();
|
|
28
|
+
theme = this._sanitizeTheme(theme);
|
|
28
29
|
const url = sap.ui.require.toUrl("sap/fe/controls/shortcuts/popup/index.html");
|
|
29
30
|
const localOrigin = window.location.protocol + "//" + window.location.host;
|
|
30
31
|
// We pass the theme and the origin to the popup so that it can communicate safely with the parent
|
|
@@ -68,6 +69,41 @@ export default class ShortcutExplanationProvider extends ManagedObject {
|
|
|
68
69
|
}
|
|
69
70
|
}
|
|
70
71
|
|
|
72
|
+
/**
|
|
73
|
+
* Sanitizes the theme name to ensure it starts with "sap-".
|
|
74
|
+
* If the theme does not start with "sap-", it tries to get the theme from the computed styles.
|
|
75
|
+
* If it still does not find a valid theme, it defaults to "sap_horizon".
|
|
76
|
+
* This is to ensure that the popup always uses a valid theme.
|
|
77
|
+
* @param theme The theme name to sanitize
|
|
78
|
+
* @returns The sanitized theme name
|
|
79
|
+
* @private
|
|
80
|
+
*/
|
|
81
|
+
private _sanitizeTheme(theme: string): string {
|
|
82
|
+
if (!theme.startsWith("sap_")) {
|
|
83
|
+
try {
|
|
84
|
+
const computedStyles = getComputedStyle(document.documentElement);
|
|
85
|
+
theme = computedStyles.getPropertyValue("--sapSapThemeId");
|
|
86
|
+
if (!theme) {
|
|
87
|
+
const themeMetadata = computedStyles.getPropertyValue("--sapThemeMetaData-UI5-sap-ui-core");
|
|
88
|
+
if (themeMetadata) {
|
|
89
|
+
const themeMatch = JSON.parse(themeMetadata);
|
|
90
|
+
if (themeMatch && themeMatch.Extends && themeMatch.Extends.length > 0) {
|
|
91
|
+
theme = themeMatch.Extends[0];
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
} catch (e) {
|
|
96
|
+
Log.info("Cannot get theme from computed styles", e instanceof Error ? e.message : String(e));
|
|
97
|
+
theme = "sap_horizon";
|
|
98
|
+
}
|
|
99
|
+
if (!theme || !theme.startsWith("sap_")) {
|
|
100
|
+
// Final fallback to sap_horizon
|
|
101
|
+
theme = "sap_horizon";
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
return theme;
|
|
105
|
+
}
|
|
106
|
+
|
|
71
107
|
static instancePromise: Promise<ShortcutExplanationProvider | undefined>;
|
|
72
108
|
|
|
73
109
|
static instance: ShortcutExplanationProvider | undefined;
|
|
@@ -95,6 +95,13 @@ sap.ui.define(["sap/fe/base/BuildingBlockBase", "sap/fe/base/ClassSupport", "sap
|
|
|
95
95
|
var _proto = ShortcutTool.prototype;
|
|
96
96
|
_proto.setupPort = function setupPort(messagePort) {
|
|
97
97
|
messagePort.onmessage = this.onMessageReceived.bind(this);
|
|
98
|
+
// We send a message to stop the display if it is already running
|
|
99
|
+
// and then start it again to ensure we have the latest data.
|
|
100
|
+
// This is to ensure that the popup is always up-to-date with the latest shortcuts
|
|
101
|
+
// and to avoid any potential issues with the display being already running.
|
|
102
|
+
messagePort.postMessage({
|
|
103
|
+
service: "sap.ui.interaction.StopDisplay"
|
|
104
|
+
});
|
|
98
105
|
messagePort.postMessage({
|
|
99
106
|
service: "sap.ui.interaction.StartDisplay"
|
|
100
107
|
});
|
|
@@ -226,4 +233,4 @@ sap.ui.define(["sap/fe/base/BuildingBlockBase", "sap/fe/base/ClassSupport", "sap
|
|
|
226
233
|
_exports = ShortcutTool;
|
|
227
234
|
return _exports;
|
|
228
235
|
}, false);
|
|
229
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["getDocsDetail","docsPath","data","spltiPath","split","result","forEach","path","collapseDuplicate","elements","filterQuery","map","element","label","nodes","filter","node","toLowerCase","includes","some","existingNode","push","Object","entries","_ref","mapKeyToSymbol","key","translatedKey","trim","ShortcutTool","_dec","defineUI5Class","_dec2","defineReference","_dec3","_class","_class2","_BuildingBlockBase","_this","call","resourceBundle","Lib","getResourceBundleFor","_initializerDefineProperty","_descriptor","_descriptor2","state","shortcutsTree","originalTree","content","createContent","initialFocus","$searchField","current","addEventDelegate","onAfterRendering","focus","window","messagePort","setupPort","_exports","_inheritsLoose","_proto","prototype","onmessage","onMessageReceived","bind","postMessage","service","e","payload","reverse","interactions","shortcut","$ref","documentationInteraction","description","replaceAll","shortcutKeys","kbd","name","concat","onStateChange","$tree","expandToLevel","onSearch","_e","query","getParameter","isTitleMatch","isNodeMatch","_jsx","Panel","headerText","getText","width","children","SearchField","ref","placeholder","search","Tree","items","model","parameters","arrayNames","noDataText","CustomTreeItem","_jsxs","FlexBox","alignItems","renderType","justifyContent","FormattedText","htmlText","class","direction","id","context","shortcutKey","getObject","shortCutText","raw","translatedShortCutText","translated","translatedShortCutKeys","rawKey","idx","Label","text","length","BuildingBlockBase","_applyDecoratedDescriptor","configurable","enumerable","writable","initializer"],"sourceRoot":".","sources":["ShortcutTool.tsx"],"sourcesContent":["import type ResourceBundle from \"sap/base/i18n/ResourceBundle\";\nimport BuildingBlockBase from \"sap/fe/base/BuildingBlockBase\";\nimport { defineReference, defineUI5Class } from \"sap/fe/base/ClassSupport\";\nimport type { Ref } from \"sap/fe/base/jsx-runtime/jsx\";\nimport CustomTreeItem from \"sap/m/CustomTreeItem\";\nimport FlexBox from \"sap/m/FlexBox\";\nimport FormattedText from \"sap/m/FormattedText\";\nimport Label from \"sap/m/Label\";\nimport Panel from \"sap/m/Panel\";\nimport type { SearchField$SearchEvent } from \"sap/m/SearchField\";\nimport SearchField from \"sap/m/SearchField\";\nimport Tree from \"sap/m/Tree\";\nimport type Control from \"sap/ui/core/Control\";\nimport Lib from \"sap/ui/core/Lib\";\nimport type Context from \"sap/ui/model/Context\";\n\ntype NamedKeyboardInteraction = {\n\tname: string;\n\tdescription?: string;\n\tkbd: (string | { raw: string; translated: string })[];\n};\ntype DocKeyboardInteraction = {\n\tdescription: string;\n\tkbd: (string | { raw: string; translated: string })[];\n};\n\ntype RefKeyboardInteraction = {\n\t$ref: string;\n};\ntype KeyboardElements = {\n\tclass: string;\n\tid: string;\n\tlabel: string;\n\tinteractions: (NamedKeyboardInteraction | RefKeyboardInteraction)[];\n};\ntype ShortcutElement = { label: string; shortcutKeys: (string | { raw: string; translated: string })[] };\n\nfunction getDocsDetail(docsPath: string, data: object): DocKeyboardInteraction[] | undefined {\n\tconst spltiPath = docsPath.split(\"/\");\n\tlet result = data;\n\tspltiPath.forEach((path) => {\n\t\tresult = result[path as keyof typeof result];\n\t});\n\treturn result as DocKeyboardInteraction[] | undefined;\n}\n\nfunction collapseDuplicate(\n\telements: { label: string; nodes: ShortcutElement[] }[],\n\tfilterQuery: string\n): { label: string; nodes: ShortcutElement[] }[] {\n\tconst map: Record<string, ShortcutElement[]> = {};\n\telements.forEach((element) => {\n\t\tif (!map[element.label]) {\n\t\t\tmap[element.label] = [];\n\t\t}\n\t\telement.nodes\n\t\t\t.filter((node) => {\n\t\t\t\treturn node.label.toLowerCase().includes(filterQuery.toLowerCase());\n\t\t\t})\n\t\t\t.forEach((node) => {\n\t\t\t\tif (!map[element.label].some((existingNode) => existingNode.label === node.label)) {\n\t\t\t\t\tmap[element.label].push(node);\n\t\t\t\t}\n\t\t\t});\n\t});\n\treturn Object.entries(map).map(([label, nodes]) => ({ label, nodes }));\n}\n\n/**\n * Maps a keyboard key to a symbol for display purposes.\n * We need to perform the mapping based on the raw key name but return the translated key for display.\n * @param key The raw key name (e.g., \"ArrowUp\", \"Ctrl\", etc.)\n * @param translatedKey The translated key name in the proper language\n * @returns The symbol to be displayed for the key\n */\nfunction mapKeyToSymbol(key: string, translatedKey: string): string {\n\tswitch (key.trim()) {\n\t\tcase \"ArrowDown\":\n\t\t\treturn \"↓\";\n\t\tcase \"ArrowUp\":\n\t\t\treturn \"↑\";\n\t\tcase \"ArrowLeft\":\n\t\t\treturn \"←\";\n\t\tcase \"ArrowRight\":\n\t\t\treturn \"→\";\n\t\tdefault:\n\t\t\treturn translatedKey;\n\t}\n}\n\ntype ShortcutToolState = {\n\tshortcutsTree: { label: string; nodes: ShortcutElement[] }[];\n\toriginalTree: { label: string; nodes: ShortcutElement[] }[];\n\tinitialFocus: boolean;\n};\n@defineUI5Class(\"sap.fe.controls.shortcuts.popup.ShortcutTool\")\nexport default class ShortcutTool extends BuildingBlockBase<Panel, ShortcutToolState> {\n\tprivate resourceBundle: ResourceBundle = Lib.getResourceBundleFor(\"sap.fe.controls\")!;\n\n\t@defineReference()\n\t$searchField!: Ref<SearchField>;\n\n\t@defineReference()\n\t$tree!: Ref<Tree>;\n\n\tconstructor() {\n\t\tsuper();\n\t\tthis.state.shortcutsTree = [];\n\t\tthis.state.originalTree = [];\n\n\t\tthis.content = this.createContent();\n\t\tthis.state.initialFocus = true;\n\t\tthis.$searchField.current?.addEventDelegate({\n\t\t\tonAfterRendering: (): void => {\n\t\t\t\tif (this.state.initialFocus) {\n\t\t\t\t\tthis.$searchField.current?.focus();\n\t\t\t\t\tthis.state.initialFocus = false;\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\tif ((window as { messagePort?: MessagePort }).messagePort) {\n\t\t\tthis.setupPort((window as { messagePort?: MessagePort }).messagePort!);\n\t\t}\n\t}\n\n\tsetupPort(messagePort: MessagePort): void {\n\t\tmessagePort.onmessage = this.onMessageReceived.bind(this);\n\t\tmessagePort.postMessage({ service: \"sap.ui.interaction.StartDisplay\" });\n\t}\n\n\tonMessageReceived(e: MessageEvent): void {\n\t\tif (e?.data?.service === \"sap.ui.interaction.UpdateDisplay\") {\n\t\t\tconst elements = e.data.payload.elements as KeyboardElements[];\n\t\t\telements.reverse();\n\t\t\tthis.state.originalTree = elements.map((element) => {\n\t\t\t\tconst nodes: ShortcutElement[] = [];\n\t\t\t\telement.interactions.forEach((shortcut) => {\n\t\t\t\t\tif ((shortcut as RefKeyboardInteraction).$ref) {\n\t\t\t\t\t\tconst interactions = getDocsDetail((shortcut as RefKeyboardInteraction).$ref, e.data.payload);\n\t\t\t\t\t\tinteractions?.forEach((documentationInteraction) => {\n\t\t\t\t\t\t\tnodes.push({\n\t\t\t\t\t\t\t\tlabel: documentationInteraction.description.replaceAll(\"<kbd\", \"<strong\").replaceAll(\"</kbd>\", \"</strong>\"),\n\t\t\t\t\t\t\t\tshortcutKeys: documentationInteraction.kbd\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t});\n\t\t\t\t\t} else {\n\t\t\t\t\t\tnodes.push({\n\t\t\t\t\t\t\tlabel: ((shortcut as NamedKeyboardInteraction).description ?? (shortcut as NamedKeyboardInteraction).name)\n\t\t\t\t\t\t\t\t.replaceAll(\"<kbd\", \"<strong\")\n\t\t\t\t\t\t\t\t.replaceAll(\"</kbd>\", \"</strong>\"),\n\t\t\t\t\t\t\tshortcutKeys: (shortcut as NamedKeyboardInteraction).kbd\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\treturn {\n\t\t\t\t\tlabel: element.label.replaceAll(\"<kbd\", \"<strong\").replaceAll(\"</kbd>\", \"</strong>\"),\n\t\t\t\t\tnodes: nodes\n\t\t\t\t};\n\t\t\t});\n\t\t}\n\t\tthis.state.shortcutsTree = collapseDuplicate(this.state.originalTree.concat(), \"\");\n\t}\n\n\tonStateChange(): void {\n\t\tthis.$tree.current?.expandToLevel(1);\n\t}\n\n\tonSearch(_e: SearchField$SearchEvent): void {\n\t\tconst query = _e.getParameter(\"query\") ?? \"\";\n\t\tthis.state.shortcutsTree = collapseDuplicate(\n\t\t\tthis.state.originalTree\n\t\t\t\t.filter((element) => {\n\t\t\t\t\tconst isTitleMatch = element.label.toLowerCase().includes(query.toLowerCase());\n\t\t\t\t\tconst isNodeMatch = element.nodes.some((node) => node.label.toLowerCase().includes(query.toLowerCase()));\n\t\t\t\t\treturn isTitleMatch || isNodeMatch;\n\t\t\t\t})\n\t\t\t\t.concat(),\n\t\t\tquery\n\t\t);\n\t}\n\n\tcreateContent(): Panel {\n\t\treturn (\n\t\t\t<Panel headerText={this.resourceBundle.getText(\"C_SHORTCUT_TITLE\")} width=\"100%\">\n\t\t\t\t{{\n\t\t\t\t\tcontent: [\n\t\t\t\t\t\t<SearchField\n\t\t\t\t\t\t\tref={this.$searchField}\n\t\t\t\t\t\t\tplaceholder={this.resourceBundle.getText(\"C_SHORTCUT_PLACEHOLDER\")}\n\t\t\t\t\t\t\tsearch={(e): void => this.onSearch(e)}\n\t\t\t\t\t\t/>,\n\t\t\t\t\t\t<Tree\n\t\t\t\t\t\t\tref={this.$tree}\n\t\t\t\t\t\t\titems={{ model: \"$componentState\", path: \"/shortcutsTree\", parameters: { arrayNames: [\"nodes\"] } }}\n\t\t\t\t\t\t\tnoDataText={this.resourceBundle.getText(\"C_SHORTCUT_NODATA\")}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<CustomTreeItem>\n\t\t\t\t\t\t\t\t<FlexBox alignItems={\"Start\"} width={\"100%\"} renderType={\"Bare\"} justifyContent={\"SpaceBetween\"}>\n\t\t\t\t\t\t\t\t\t<FormattedText htmlText={this.state.shortcutsTree.label} class={\"sapFeControlsShorcutMFT\"} />\n\t\t\t\t\t\t\t\t\t<FlexBox\n\t\t\t\t\t\t\t\t\t\trenderType={\"Bare\"}\n\t\t\t\t\t\t\t\t\t\tjustifyContent={\"SpaceBetween\"}\n\t\t\t\t\t\t\t\t\t\titems={\"{$componentState>shortcutKeys}\"}\n\t\t\t\t\t\t\t\t\t\tdirection={\"Column\"}\n\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t{{\n\t\t\t\t\t\t\t\t\t\t\titems: function (id: string, context: Context): Label {\n\t\t\t\t\t\t\t\t\t\t\t\tconst shortcutKey = context.getObject() as string | { raw: string; translated: string };\n\t\t\t\t\t\t\t\t\t\t\t\tconst shortCutText = typeof shortcutKey === \"string\" ? shortcutKey : shortcutKey.raw;\n\t\t\t\t\t\t\t\t\t\t\t\tconst translatedShortCutText =\n\t\t\t\t\t\t\t\t\t\t\t\t\ttypeof shortcutKey === \"string\" ? shortcutKey : shortcutKey.translated;\n\t\t\t\t\t\t\t\t\t\t\t\tconst shortcutKeys = shortCutText.split(\"+\");\n\t\t\t\t\t\t\t\t\t\t\t\tconst translatedShortCutKeys = translatedShortCutText.split(\"+\");\n\t\t\t\t\t\t\t\t\t\t\t\tconst elements: Control[] = [];\n\t\t\t\t\t\t\t\t\t\t\t\tshortcutKeys.forEach((rawKey: string, idx: number) => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tconst translatedKey = translatedShortCutKeys[idx] ?? rawKey;\n\t\t\t\t\t\t\t\t\t\t\t\t\telements.push(\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t<Label\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttext={mapKeyToSymbol(rawKey, translatedKey)}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tclass={\"sapUiTinyMarginEnd sapFeControlsShortcutKey\"}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (idx !== shortcutKeys.length - 1) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\telements.push(<Label text={\"+\"} class={\"sapUiTinyMarginEnd\"} />);\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t\t\t\t\t<FlexBox id={id} renderType={\"Bare\"} alignItems={\"Center\"}>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t{{ items: elements }}\n\t\t\t\t\t\t\t\t\t\t\t\t\t</FlexBox>\n\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t</FlexBox>\n\t\t\t\t\t\t\t\t</FlexBox>\n\t\t\t\t\t\t\t</CustomTreeItem>\n\t\t\t\t\t\t</Tree>\n\t\t\t\t\t]\n\t\t\t\t}}\n\t\t\t</Panel>\n\t\t);\n\t}\n}\n"],"mappings":"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","ignoreList":[]}
|
|
236
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["getDocsDetail","docsPath","data","spltiPath","split","result","forEach","path","collapseDuplicate","elements","filterQuery","map","element","label","nodes","filter","node","toLowerCase","includes","some","existingNode","push","Object","entries","_ref","mapKeyToSymbol","key","translatedKey","trim","ShortcutTool","_dec","defineUI5Class","_dec2","defineReference","_dec3","_class","_class2","_BuildingBlockBase","_this","call","resourceBundle","Lib","getResourceBundleFor","_initializerDefineProperty","_descriptor","_descriptor2","state","shortcutsTree","originalTree","content","createContent","initialFocus","$searchField","current","addEventDelegate","onAfterRendering","focus","window","messagePort","setupPort","_exports","_inheritsLoose","_proto","prototype","onmessage","onMessageReceived","bind","postMessage","service","e","payload","reverse","interactions","shortcut","$ref","documentationInteraction","description","replaceAll","shortcutKeys","kbd","name","concat","onStateChange","$tree","expandToLevel","onSearch","_e","query","getParameter","isTitleMatch","isNodeMatch","_jsx","Panel","headerText","getText","width","children","SearchField","ref","placeholder","search","Tree","items","model","parameters","arrayNames","noDataText","CustomTreeItem","_jsxs","FlexBox","alignItems","renderType","justifyContent","FormattedText","htmlText","class","direction","id","context","shortcutKey","getObject","shortCutText","raw","translatedShortCutText","translated","translatedShortCutKeys","rawKey","idx","Label","text","length","BuildingBlockBase","_applyDecoratedDescriptor","configurable","enumerable","writable","initializer"],"sourceRoot":".","sources":["ShortcutTool.tsx"],"sourcesContent":["import type ResourceBundle from \"sap/base/i18n/ResourceBundle\";\nimport BuildingBlockBase from \"sap/fe/base/BuildingBlockBase\";\nimport { defineReference, defineUI5Class } from \"sap/fe/base/ClassSupport\";\nimport type { Ref } from \"sap/fe/base/jsx-runtime/jsx\";\nimport CustomTreeItem from \"sap/m/CustomTreeItem\";\nimport FlexBox from \"sap/m/FlexBox\";\nimport FormattedText from \"sap/m/FormattedText\";\nimport Label from \"sap/m/Label\";\nimport Panel from \"sap/m/Panel\";\nimport type { SearchField$SearchEvent } from \"sap/m/SearchField\";\nimport SearchField from \"sap/m/SearchField\";\nimport Tree from \"sap/m/Tree\";\nimport type Control from \"sap/ui/core/Control\";\nimport Lib from \"sap/ui/core/Lib\";\nimport type Context from \"sap/ui/model/Context\";\n\ntype NamedKeyboardInteraction = {\n\tname: string;\n\tdescription?: string;\n\tkbd: (string | { raw: string; translated: string })[];\n};\ntype DocKeyboardInteraction = {\n\tdescription: string;\n\tkbd: (string | { raw: string; translated: string })[];\n};\n\ntype RefKeyboardInteraction = {\n\t$ref: string;\n};\ntype KeyboardElements = {\n\tclass: string;\n\tid: string;\n\tlabel: string;\n\tinteractions: (NamedKeyboardInteraction | RefKeyboardInteraction)[];\n};\ntype ShortcutElement = { label: string; shortcutKeys: (string | { raw: string; translated: string })[] };\n\nfunction getDocsDetail(docsPath: string, data: object): DocKeyboardInteraction[] | undefined {\n\tconst spltiPath = docsPath.split(\"/\");\n\tlet result = data;\n\tspltiPath.forEach((path) => {\n\t\tresult = result[path as keyof typeof result];\n\t});\n\treturn result as DocKeyboardInteraction[] | undefined;\n}\n\nfunction collapseDuplicate(\n\telements: { label: string; nodes: ShortcutElement[] }[],\n\tfilterQuery: string\n): { label: string; nodes: ShortcutElement[] }[] {\n\tconst map: Record<string, ShortcutElement[]> = {};\n\telements.forEach((element) => {\n\t\tif (!map[element.label]) {\n\t\t\tmap[element.label] = [];\n\t\t}\n\t\telement.nodes\n\t\t\t.filter((node) => {\n\t\t\t\treturn node.label.toLowerCase().includes(filterQuery.toLowerCase());\n\t\t\t})\n\t\t\t.forEach((node) => {\n\t\t\t\tif (!map[element.label].some((existingNode) => existingNode.label === node.label)) {\n\t\t\t\t\tmap[element.label].push(node);\n\t\t\t\t}\n\t\t\t});\n\t});\n\treturn Object.entries(map).map(([label, nodes]) => ({ label, nodes }));\n}\n\n/**\n * Maps a keyboard key to a symbol for display purposes.\n * We need to perform the mapping based on the raw key name but return the translated key for display.\n * @param key The raw key name (e.g., \"ArrowUp\", \"Ctrl\", etc.)\n * @param translatedKey The translated key name in the proper language\n * @returns The symbol to be displayed for the key\n */\nfunction mapKeyToSymbol(key: string, translatedKey: string): string {\n\tswitch (key.trim()) {\n\t\tcase \"ArrowDown\":\n\t\t\treturn \"↓\";\n\t\tcase \"ArrowUp\":\n\t\t\treturn \"↑\";\n\t\tcase \"ArrowLeft\":\n\t\t\treturn \"←\";\n\t\tcase \"ArrowRight\":\n\t\t\treturn \"→\";\n\t\tdefault:\n\t\t\treturn translatedKey;\n\t}\n}\n\ntype ShortcutToolState = {\n\tshortcutsTree: { label: string; nodes: ShortcutElement[] }[];\n\toriginalTree: { label: string; nodes: ShortcutElement[] }[];\n\tinitialFocus: boolean;\n};\n@defineUI5Class(\"sap.fe.controls.shortcuts.popup.ShortcutTool\")\nexport default class ShortcutTool extends BuildingBlockBase<Panel, ShortcutToolState> {\n\tprivate resourceBundle: ResourceBundle = Lib.getResourceBundleFor(\"sap.fe.controls\")!;\n\n\t@defineReference()\n\t$searchField!: Ref<SearchField>;\n\n\t@defineReference()\n\t$tree!: Ref<Tree>;\n\n\tconstructor() {\n\t\tsuper();\n\t\tthis.state.shortcutsTree = [];\n\t\tthis.state.originalTree = [];\n\n\t\tthis.content = this.createContent();\n\t\tthis.state.initialFocus = true;\n\t\tthis.$searchField.current?.addEventDelegate({\n\t\t\tonAfterRendering: (): void => {\n\t\t\t\tif (this.state.initialFocus) {\n\t\t\t\t\tthis.$searchField.current?.focus();\n\t\t\t\t\tthis.state.initialFocus = false;\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\tif ((window as { messagePort?: MessagePort }).messagePort) {\n\t\t\tthis.setupPort((window as { messagePort?: MessagePort }).messagePort!);\n\t\t}\n\t}\n\n\tsetupPort(messagePort: MessagePort): void {\n\t\tmessagePort.onmessage = this.onMessageReceived.bind(this);\n\t\t// We send a message to stop the display if it is already running\n\t\t// and then start it again to ensure we have the latest data.\n\t\t// This is to ensure that the popup is always up-to-date with the latest shortcuts\n\t\t// and to avoid any potential issues with the display being already running.\n\t\tmessagePort.postMessage({ service: \"sap.ui.interaction.StopDisplay\" });\n\t\tmessagePort.postMessage({ service: \"sap.ui.interaction.StartDisplay\" });\n\t}\n\n\tonMessageReceived(e: MessageEvent): void {\n\t\tif (e?.data?.service === \"sap.ui.interaction.UpdateDisplay\") {\n\t\t\tconst elements = e.data.payload.elements as KeyboardElements[];\n\t\t\telements.reverse();\n\t\t\tthis.state.originalTree = elements.map((element) => {\n\t\t\t\tconst nodes: ShortcutElement[] = [];\n\t\t\t\telement.interactions.forEach((shortcut) => {\n\t\t\t\t\tif ((shortcut as RefKeyboardInteraction).$ref) {\n\t\t\t\t\t\tconst interactions = getDocsDetail((shortcut as RefKeyboardInteraction).$ref, e.data.payload);\n\t\t\t\t\t\tinteractions?.forEach((documentationInteraction) => {\n\t\t\t\t\t\t\tnodes.push({\n\t\t\t\t\t\t\t\tlabel: documentationInteraction.description.replaceAll(\"<kbd\", \"<strong\").replaceAll(\"</kbd>\", \"</strong>\"),\n\t\t\t\t\t\t\t\tshortcutKeys: documentationInteraction.kbd\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t});\n\t\t\t\t\t} else {\n\t\t\t\t\t\tnodes.push({\n\t\t\t\t\t\t\tlabel: ((shortcut as NamedKeyboardInteraction).description ?? (shortcut as NamedKeyboardInteraction).name)\n\t\t\t\t\t\t\t\t.replaceAll(\"<kbd\", \"<strong\")\n\t\t\t\t\t\t\t\t.replaceAll(\"</kbd>\", \"</strong>\"),\n\t\t\t\t\t\t\tshortcutKeys: (shortcut as NamedKeyboardInteraction).kbd\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\treturn {\n\t\t\t\t\tlabel: element.label.replaceAll(\"<kbd\", \"<strong\").replaceAll(\"</kbd>\", \"</strong>\"),\n\t\t\t\t\tnodes: nodes\n\t\t\t\t};\n\t\t\t});\n\t\t}\n\t\tthis.state.shortcutsTree = collapseDuplicate(this.state.originalTree.concat(), \"\");\n\t}\n\n\tonStateChange(): void {\n\t\tthis.$tree.current?.expandToLevel(1);\n\t}\n\n\tonSearch(_e: SearchField$SearchEvent): void {\n\t\tconst query = _e.getParameter(\"query\") ?? \"\";\n\t\tthis.state.shortcutsTree = collapseDuplicate(\n\t\t\tthis.state.originalTree\n\t\t\t\t.filter((element) => {\n\t\t\t\t\tconst isTitleMatch = element.label.toLowerCase().includes(query.toLowerCase());\n\t\t\t\t\tconst isNodeMatch = element.nodes.some((node) => node.label.toLowerCase().includes(query.toLowerCase()));\n\t\t\t\t\treturn isTitleMatch || isNodeMatch;\n\t\t\t\t})\n\t\t\t\t.concat(),\n\t\t\tquery\n\t\t);\n\t}\n\n\tcreateContent(): Panel {\n\t\treturn (\n\t\t\t<Panel headerText={this.resourceBundle.getText(\"C_SHORTCUT_TITLE\")} width=\"100%\">\n\t\t\t\t{{\n\t\t\t\t\tcontent: [\n\t\t\t\t\t\t<SearchField\n\t\t\t\t\t\t\tref={this.$searchField}\n\t\t\t\t\t\t\tplaceholder={this.resourceBundle.getText(\"C_SHORTCUT_PLACEHOLDER\")}\n\t\t\t\t\t\t\tsearch={(e): void => this.onSearch(e)}\n\t\t\t\t\t\t/>,\n\t\t\t\t\t\t<Tree\n\t\t\t\t\t\t\tref={this.$tree}\n\t\t\t\t\t\t\titems={{ model: \"$componentState\", path: \"/shortcutsTree\", parameters: { arrayNames: [\"nodes\"] } }}\n\t\t\t\t\t\t\tnoDataText={this.resourceBundle.getText(\"C_SHORTCUT_NODATA\")}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<CustomTreeItem>\n\t\t\t\t\t\t\t\t<FlexBox alignItems={\"Start\"} width={\"100%\"} renderType={\"Bare\"} justifyContent={\"SpaceBetween\"}>\n\t\t\t\t\t\t\t\t\t<FormattedText htmlText={this.state.shortcutsTree.label} class={\"sapFeControlsShorcutMFT\"} />\n\t\t\t\t\t\t\t\t\t<FlexBox\n\t\t\t\t\t\t\t\t\t\trenderType={\"Bare\"}\n\t\t\t\t\t\t\t\t\t\tjustifyContent={\"SpaceBetween\"}\n\t\t\t\t\t\t\t\t\t\titems={\"{$componentState>shortcutKeys}\"}\n\t\t\t\t\t\t\t\t\t\tdirection={\"Column\"}\n\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t{{\n\t\t\t\t\t\t\t\t\t\t\titems: function (id: string, context: Context): Label {\n\t\t\t\t\t\t\t\t\t\t\t\tconst shortcutKey = context.getObject() as string | { raw: string; translated: string };\n\t\t\t\t\t\t\t\t\t\t\t\tconst shortCutText = typeof shortcutKey === \"string\" ? shortcutKey : shortcutKey.raw;\n\t\t\t\t\t\t\t\t\t\t\t\tconst translatedShortCutText =\n\t\t\t\t\t\t\t\t\t\t\t\t\ttypeof shortcutKey === \"string\" ? shortcutKey : shortcutKey.translated;\n\t\t\t\t\t\t\t\t\t\t\t\tconst shortcutKeys = shortCutText.split(\"+\");\n\t\t\t\t\t\t\t\t\t\t\t\tconst translatedShortCutKeys = translatedShortCutText.split(\"+\");\n\t\t\t\t\t\t\t\t\t\t\t\tconst elements: Control[] = [];\n\t\t\t\t\t\t\t\t\t\t\t\tshortcutKeys.forEach((rawKey: string, idx: number) => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tconst translatedKey = translatedShortCutKeys[idx] ?? rawKey;\n\t\t\t\t\t\t\t\t\t\t\t\t\telements.push(\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t<Label\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\ttext={mapKeyToSymbol(rawKey, translatedKey)}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t\tclass={\"sapUiTinyMarginEnd sapFeControlsShortcutKey\"}\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\t\t\tif (idx !== shortcutKeys.length - 1) {\n\t\t\t\t\t\t\t\t\t\t\t\t\t\telements.push(<Label text={\"+\"} class={\"sapUiTinyMarginEnd\"} />);\n\t\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t\t\t\t\t<FlexBox id={id} renderType={\"Bare\"} alignItems={\"Center\"}>\n\t\t\t\t\t\t\t\t\t\t\t\t\t\t{{ items: elements }}\n\t\t\t\t\t\t\t\t\t\t\t\t\t</FlexBox>\n\t\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t</FlexBox>\n\t\t\t\t\t\t\t\t</FlexBox>\n\t\t\t\t\t\t\t</CustomTreeItem>\n\t\t\t\t\t\t</Tree>\n\t\t\t\t\t]\n\t\t\t\t}}\n\t\t\t</Panel>\n\t\t);\n\t}\n}\n"],"mappings":";;;;;;;;;;;;;;;;EAqCA,SAASA,aAAaA,CAACC,QAAgB,EAAEC,IAAY,EAAwC;IAC5F,MAAMC,SAAS,GAAGF,QAAQ,CAACG,KAAK,CAAC,GAAG,CAAC;IACrC,IAAIC,MAAM,GAAGH,IAAI;IACjBC,SAAS,CAACG,OAAO,CAAEC,IAAI,IAAK;MAC3BF,MAAM,GAAGA,MAAM,CAACE,IAAI,CAAwB;IAC7C,CAAC,CAAC;IACF,OAAOF,MAAM;EACd;EAEA,SAASG,iBAAiBA,CACzBC,QAAuD,EACvDC,WAAmB,EAC6B;IAChD,MAAMC,GAAsC,GAAG,CAAC,CAAC;IACjDF,QAAQ,CAACH,OAAO,CAAEM,OAAO,IAAK;MAC7B,IAAI,CAACD,GAAG,CAACC,OAAO,CAACC,KAAK,CAAC,EAAE;QACxBF,GAAG,CAACC,OAAO,CAACC,KAAK,CAAC,GAAG,EAAE;MACxB;MACAD,OAAO,CAACE,KAAK,CACXC,MAAM,CAAEC,IAAI,IAAK;QACjB,OAAOA,IAAI,CAACH,KAAK,CAACI,WAAW,CAAC,CAAC,CAACC,QAAQ,CAACR,WAAW,CAACO,WAAW,CAAC,CAAC,CAAC;MACpE,CAAC,CAAC,CACDX,OAAO,CAAEU,IAAI,IAAK;QAClB,IAAI,CAACL,GAAG,CAACC,OAAO,CAACC,KAAK,CAAC,CAACM,IAAI,CAAEC,YAAY,IAAKA,YAAY,CAACP,KAAK,KAAKG,IAAI,CAACH,KAAK,CAAC,EAAE;UAClFF,GAAG,CAACC,OAAO,CAACC,KAAK,CAAC,CAACQ,IAAI,CAACL,IAAI,CAAC;QAC9B;MACD,CAAC,CAAC;IACJ,CAAC,CAAC;IACF,OAAOM,MAAM,CAACC,OAAO,CAACZ,GAAG,CAAC,CAACA,GAAG,CAACa,IAAA;MAAA,IAAC,CAACX,KAAK,EAAEC,KAAK,CAAC,GAAAU,IAAA;MAAA,OAAM;QAAEX,KAAK;QAAEC;MAAM,CAAC;IAAA,CAAC,CAAC;EACvE;;EAEA;AACA;AACA;AACA;AACA;AACA;AACA;EACA,SAASW,cAAcA,CAACC,GAAW,EAAEC,aAAqB,EAAU;IACnE,QAAQD,GAAG,CAACE,IAAI,CAAC,CAAC;MACjB,KAAK,WAAW;QACf,OAAO,GAAG;MACX,KAAK,SAAS;QACb,OAAO,GAAG;MACX,KAAK,WAAW;QACf,OAAO,GAAG;MACX,KAAK,YAAY;QAChB,OAAO,GAAG;MACX;QACC,OAAOD,aAAa;IACtB;EACD;EAAC,IAQoBE,YAAY,IAAAC,IAAA,GADhCC,cAAc,CAAC,8CAA8C,CAAC,EAAAC,KAAA,GAI7DC,eAAe,CAAC,CAAC,EAAAC,KAAA,GAGjBD,eAAe,CAAC,CAAC,EAAAH,IAAA,CAAAK,MAAA,IAAAC,OAAA,0BAAAC,kBAAA;IAGlB,SAAAR,aAAA,EAAc;MAAA,IAAAS,KAAA;MACbA,KAAA,GAAAD,kBAAA,CAAAE,IAAA,KAAM,CAAC;MAACD,KAAA,CATDE,cAAc,GAAmBC,GAAG,CAACC,oBAAoB,CAAC,iBAAiB,CAAC;MAAAC,0BAAA,CAAAL,KAAA,kBAAAM,WAAA,EAAAN,KAAA;MAAAK,0BAAA,CAAAL,KAAA,WAAAO,YAAA,EAAAP,KAAA;MAUnFA,KAAA,CAAKQ,KAAK,CAACC,aAAa,GAAG,EAAE;MAC7BT,KAAA,CAAKQ,KAAK,CAACE,YAAY,GAAG,EAAE;MAE5BV,KAAA,CAAKW,OAAO,GAAGX,KAAA,CAAKY,aAAa,CAAC,CAAC;MACnCZ,KAAA,CAAKQ,KAAK,CAACK,YAAY,GAAG,IAAI;MAC9Bb,KAAA,CAAKc,YAAY,CAACC,OAAO,EAAEC,gBAAgB,CAAC;QAC3CC,gBAAgB,EAAEA,CAAA,KAAY;UAC7B,IAAIjB,KAAA,CAAKQ,KAAK,CAACK,YAAY,EAAE;YAC5Bb,KAAA,CAAKc,YAAY,CAACC,OAAO,EAAEG,KAAK,CAAC,CAAC;YAClClB,KAAA,CAAKQ,KAAK,CAACK,YAAY,GAAG,KAAK;UAChC;QACD;MACD,CAAC,CAAC;MAEF,IAAKM,MAAM,CAAmCC,WAAW,EAAE;QAC1DpB,KAAA,CAAKqB,SAAS,CAAEF,MAAM,CAAmCC,WAAY,CAAC;MACvE;MAAC,OAAApB,KAAA;IACF;IAACsB,QAAA,GAAA/B,YAAA;IAAAgC,cAAA,CAAAhC,YAAA,EAAAQ,kBAAA;IAAA,IAAAyB,MAAA,GAAAjC,YAAA,CAAAkC,SAAA;IAAAD,MAAA,CAEDH,SAAS,GAAT,SAAAA,SAASA,CAACD,WAAwB,EAAQ;MACzCA,WAAW,CAACM,SAAS,GAAG,IAAI,CAACC,iBAAiB,CAACC,IAAI,CAAC,IAAI,CAAC;MACzD;MACA;MACA;MACA;MACAR,WAAW,CAACS,WAAW,CAAC;QAAEC,OAAO,EAAE;MAAiC,CAAC,CAAC;MACtEV,WAAW,CAACS,WAAW,CAAC;QAAEC,OAAO,EAAE;MAAkC,CAAC,CAAC;IACxE,CAAC;IAAAN,MAAA,CAEDG,iBAAiB,GAAjB,SAAAA,iBAAiBA,CAACI,CAAe,EAAQ;MACxC,IAAIA,CAAC,EAAEnE,IAAI,EAAEkE,OAAO,KAAK,kCAAkC,EAAE;QAC5D,MAAM3D,QAAQ,GAAG4D,CAAC,CAACnE,IAAI,CAACoE,OAAO,CAAC7D,QAA8B;QAC9DA,QAAQ,CAAC8D,OAAO,CAAC,CAAC;QAClB,IAAI,CAACzB,KAAK,CAACE,YAAY,GAAGvC,QAAQ,CAACE,GAAG,CAAEC,OAAO,IAAK;UACnD,MAAME,KAAwB,GAAG,EAAE;UACnCF,OAAO,CAAC4D,YAAY,CAAClE,OAAO,CAAEmE,QAAQ,IAAK;YAC1C,IAAKA,QAAQ,CAA4BC,IAAI,EAAE;cAC9C,MAAMF,YAAY,GAAGxE,aAAa,CAAEyE,QAAQ,CAA4BC,IAAI,EAAEL,CAAC,CAACnE,IAAI,CAACoE,OAAO,CAAC;cAC7FE,YAAY,EAAElE,OAAO,CAAEqE,wBAAwB,IAAK;gBACnD7D,KAAK,CAACO,IAAI,CAAC;kBACVR,KAAK,EAAE8D,wBAAwB,CAACC,WAAW,CAACC,UAAU,CAAC,MAAM,EAAE,SAAS,CAAC,CAACA,UAAU,CAAC,QAAQ,EAAE,WAAW,CAAC;kBAC3GC,YAAY,EAAEH,wBAAwB,CAACI;gBACxC,CAAC,CAAC;cACH,CAAC,CAAC;YACH,CAAC,MAAM;cACNjE,KAAK,CAACO,IAAI,CAAC;gBACVR,KAAK,EAAE,CAAE4D,QAAQ,CAA8BG,WAAW,IAAKH,QAAQ,CAA8BO,IAAI,EACvGH,UAAU,CAAC,MAAM,EAAE,SAAS,CAAC,CAC7BA,UAAU,CAAC,QAAQ,EAAE,WAAW,CAAC;gBACnCC,YAAY,EAAGL,QAAQ,CAA8BM;cACtD,CAAC,CAAC;YACH;UACD,CAAC,CAAC;UACF,OAAO;YACNlE,KAAK,EAAED,OAAO,CAACC,KAAK,CAACgE,UAAU,CAAC,MAAM,EAAE,SAAS,CAAC,CAACA,UAAU,CAAC,QAAQ,EAAE,WAAW,CAAC;YACpF/D,KAAK,EAAEA;UACR,CAAC;QACF,CAAC,CAAC;MACH;MACA,IAAI,CAACgC,KAAK,CAACC,aAAa,GAAGvC,iBAAiB,CAAC,IAAI,CAACsC,KAAK,CAACE,YAAY,CAACiC,MAAM,CAAC,CAAC,EAAE,EAAE,CAAC;IACnF,CAAC;IAAAnB,MAAA,CAEDoB,aAAa,GAAb,SAAAA,aAAaA,CAAA,EAAS;MACrB,IAAI,CAACC,KAAK,CAAC9B,OAAO,EAAE+B,aAAa,CAAC,CAAC,CAAC;IACrC,CAAC;IAAAtB,MAAA,CAEDuB,QAAQ,GAAR,SAAAA,QAAQA,CAACC,EAA2B,EAAQ;MAC3C,MAAMC,KAAK,GAAGD,EAAE,CAACE,YAAY,CAAC,OAAO,CAAC,IAAI,EAAE;MAC5C,IAAI,CAAC1C,KAAK,CAACC,aAAa,GAAGvC,iBAAiB,CAC3C,IAAI,CAACsC,KAAK,CAACE,YAAY,CACrBjC,MAAM,CAAEH,OAAO,IAAK;QACpB,MAAM6E,YAAY,GAAG7E,OAAO,CAACC,KAAK,CAACI,WAAW,CAAC,CAAC,CAACC,QAAQ,CAACqE,KAAK,CAACtE,WAAW,CAAC,CAAC,CAAC;QAC9E,MAAMyE,WAAW,GAAG9E,OAAO,CAACE,KAAK,CAACK,IAAI,CAAEH,IAAI,IAAKA,IAAI,CAACH,KAAK,CAACI,WAAW,CAAC,CAAC,CAACC,QAAQ,CAACqE,KAAK,CAACtE,WAAW,CAAC,CAAC,CAAC,CAAC;QACxG,OAAOwE,YAAY,IAAIC,WAAW;MACnC,CAAC,CAAC,CACDT,MAAM,CAAC,CAAC,EACVM,KACD,CAAC;IACF,CAAC;IAAAzB,MAAA,CAEDZ,aAAa,GAAb,SAAAA,aAAaA,CAAA,EAAU;MACtB,OACCyC,IAAA,CAACC,KAAK;QAACC,UAAU,EAAE,IAAI,CAACrD,cAAc,CAACsD,OAAO,CAAC,kBAAkB,CAAE;QAACC,KAAK,EAAC,MAAM;QAAAC,QAAA,EAC9E;UACA/C,OAAO,EAAE,CACR0C,IAAA,CAACM,WAAW;YACXC,GAAG,EAAE,IAAI,CAAC9C,YAAa;YACvB+C,WAAW,EAAE,IAAI,CAAC3D,cAAc,CAACsD,OAAO,CAAC,wBAAwB,CAAE;YACnEM,MAAM,EAAG/B,CAAC,IAAW,IAAI,CAACgB,QAAQ,CAAChB,CAAC;UAAE,CACtC,CAAC,EACFsB,IAAA,CAACU,IAAI;YACJH,GAAG,EAAE,IAAI,CAACf,KAAM;YAChBmB,KAAK,EAAE;cAAEC,KAAK,EAAE,iBAAiB;cAAEhG,IAAI,EAAE,gBAAgB;cAAEiG,UAAU,EAAE;gBAAEC,UAAU,EAAE,CAAC,OAAO;cAAE;YAAE,CAAE;YACnGC,UAAU,EAAE,IAAI,CAAClE,cAAc,CAACsD,OAAO,CAAC,mBAAmB,CAAE;YAAAE,QAAA,EAE7DL,IAAA,CAACgB,cAAc;cAAAX,QAAA,EACdY,KAAA,CAACC,OAAO;gBAACC,UAAU,EAAE,OAAQ;gBAACf,KAAK,EAAE,MAAO;gBAACgB,UAAU,EAAE,MAAO;gBAACC,cAAc,EAAE,cAAe;gBAAAhB,QAAA,GAC/FL,IAAA,CAACsB,aAAa;kBAACC,QAAQ,EAAE,IAAI,CAACpE,KAAK,CAACC,aAAa,CAAClC,KAAM;kBAACsG,KAAK,EAAE;gBAA0B,CAAE,CAAC,EAC7FxB,IAAA,CAACkB,OAAO;kBACPE,UAAU,EAAE,MAAO;kBACnBC,cAAc,EAAE,cAAe;kBAC/BV,KAAK,EAAE,gCAAiC;kBACxCc,SAAS,EAAE,QAAS;kBAAApB,QAAA,EAEnB;oBACAM,KAAK,EAAE,SAAAA,CAAUe,EAAU,EAAEC,OAAgB,EAAS;sBACrD,MAAMC,WAAW,GAAGD,OAAO,CAACE,SAAS,CAAC,CAAiD;sBACvF,MAAMC,YAAY,GAAG,OAAOF,WAAW,KAAK,QAAQ,GAAGA,WAAW,GAAGA,WAAW,CAACG,GAAG;sBACpF,MAAMC,sBAAsB,GAC3B,OAAOJ,WAAW,KAAK,QAAQ,GAAGA,WAAW,GAAGA,WAAW,CAACK,UAAU;sBACvE,MAAM9C,YAAY,GAAG2C,YAAY,CAACrH,KAAK,CAAC,GAAG,CAAC;sBAC5C,MAAMyH,sBAAsB,GAAGF,sBAAsB,CAACvH,KAAK,CAAC,GAAG,CAAC;sBAChE,MAAMK,QAAmB,GAAG,EAAE;sBAC9BqE,YAAY,CAACxE,OAAO,CAAC,CAACwH,MAAc,EAAEC,GAAW,KAAK;wBACrD,MAAMpG,aAAa,GAAGkG,sBAAsB,CAACE,GAAG,CAAC,IAAID,MAAM;wBAC3DrH,QAAQ,CAACY,IAAI,CACZsE,IAAA,CAACqC,KAAK;0BACLC,IAAI,EAAExG,cAAc,CAACqG,MAAM,EAAEnG,aAAa,CAAE;0BAC5CwF,KAAK,EAAE;wBAA8C,CACrD,CACF,CAAC;wBACD,IAAIY,GAAG,KAAKjD,YAAY,CAACoD,MAAM,GAAG,CAAC,EAAE;0BACpCzH,QAAQ,CAACY,IAAI,CAACsE,IAAA,CAACqC,KAAK;4BAACC,IAAI,EAAE,GAAI;4BAACd,KAAK,EAAE;0BAAqB,CAAE,CAAC,CAAC;wBACjE;sBACD,CAAC,CAAC;sBACF,OACCxB,IAAA,CAACkB,OAAO;wBAACQ,EAAE,EAAEA,EAAG;wBAACN,UAAU,EAAE,MAAO;wBAACD,UAAU,EAAE,QAAS;wBAAAd,QAAA,EACxD;0BAAEM,KAAK,EAAE7F;wBAAS;sBAAC,CACZ,CAAC;oBAEZ;kBACD;gBAAC,CACO,CAAC;cAAA,CACF;YAAC,CACK;UAAC,CACZ,CAAC;QAET;MAAC,CACK,CAAC;IAEV,CAAC;IAAA,OAAAoB,YAAA;EAAA,EAvJwCsG,iBAAiB,GAAAvF,WAAA,GAAAwF,yBAAA,CAAAhG,OAAA,CAAA2B,SAAA,mBAAA/B,KAAA;IAAAqG,YAAA;IAAAC,UAAA;IAAAC,QAAA;IAAAC,WAAA;EAAA,IAAA3F,YAAA,GAAAuF,yBAAA,CAAAhG,OAAA,CAAA2B,SAAA,YAAA7B,KAAA;IAAAmG,YAAA;IAAAC,UAAA;IAAAC,QAAA;IAAAC,WAAA;EAAA,IAAApG,OAAA,MAAAD,MAAA;EAAAyB,QAAA,GAAA/B,YAAA;EAAA,OAAA+B,QAAA;AAAA","ignoreList":[]}
|
|
@@ -126,6 +126,11 @@ export default class ShortcutTool extends BuildingBlockBase<Panel, ShortcutToolS
|
|
|
126
126
|
|
|
127
127
|
setupPort(messagePort: MessagePort): void {
|
|
128
128
|
messagePort.onmessage = this.onMessageReceived.bind(this);
|
|
129
|
+
// We send a message to stop the display if it is already running
|
|
130
|
+
// and then start it again to ensure we have the latest data.
|
|
131
|
+
// This is to ensure that the popup is always up-to-date with the latest shortcuts
|
|
132
|
+
// and to avoid any potential issues with the display being already running.
|
|
133
|
+
messagePort.postMessage({ service: "sap.ui.interaction.StopDisplay" });
|
|
129
134
|
messagePort.postMessage({ service: "sap.ui.interaction.StartDisplay" });
|
|
130
135
|
}
|
|
131
136
|
|