mirror of
https://github.com/zadam/trilium.git
synced 2025-11-10 08:29:00 +01:00
34 lines
1.0 KiB
TypeScript
34 lines
1.0 KiB
TypeScript
import { ActionKeyboardShortcut, KeyboardActionNames } from "@triliumnext/commons";
|
|
import { useEffect, useState } from "preact/hooks";
|
|
import keyboard_actions from "../../services/keyboard_actions";
|
|
import { joinElements } from "./react_utils";
|
|
import utils from "../../services/utils";
|
|
|
|
interface KeyboardShortcutProps {
|
|
actionName: KeyboardActionNames;
|
|
}
|
|
|
|
const isMobile = utils.isMobile();
|
|
|
|
export default function KeyboardShortcut({ actionName }: KeyboardShortcutProps) {
|
|
|
|
const [ action, setAction ] = useState<ActionKeyboardShortcut>();
|
|
useEffect(() => {
|
|
keyboard_actions.getAction(actionName).then(setAction);
|
|
}, []);
|
|
|
|
if (!action) {
|
|
return <></>;
|
|
}
|
|
|
|
return (!isMobile &&
|
|
<span className="keyboard-shortcut">
|
|
{joinElements(action.effectiveShortcuts?.map((shortcut) => {
|
|
const keys = shortcut.split("+");
|
|
return joinElements(
|
|
keys.map((key, i) => <kbd>{key}</kbd>)
|
|
, "+");
|
|
}))}
|
|
</span>
|
|
);
|
|
} |