2022-04-25 16:33:38 +08:00
|
|
|
import { isMacLike } from "../../common/util";
|
2022-04-13 20:46:52 +08:00
|
|
|
import { FilterList } from "./filter";
|
2022-03-20 16:56:28 +08:00
|
|
|
import { faPersonRunning } from "@fortawesome/free-solid-svg-icons";
|
2022-03-29 17:21:32 +08:00
|
|
|
import { AppCommand } from "../hooks/command";
|
2022-04-21 19:57:45 +08:00
|
|
|
import { FilterOption } from "@silverbulletmd/common/types";
|
2022-03-20 16:56:28 +08:00
|
|
|
|
|
|
|
export function CommandPalette({
|
|
|
|
commands,
|
2022-05-16 21:09:36 +08:00
|
|
|
recentCommands,
|
2022-03-20 16:56:28 +08:00
|
|
|
onTrigger,
|
|
|
|
}: {
|
|
|
|
commands: Map<string, AppCommand>;
|
2022-05-16 21:09:36 +08:00
|
|
|
recentCommands: Map<string, Date>;
|
2022-03-20 16:56:28 +08:00
|
|
|
onTrigger: (command: AppCommand | undefined) => void;
|
|
|
|
}) {
|
2022-04-13 20:46:52 +08:00
|
|
|
let options: FilterOption[] = [];
|
2022-03-20 16:56:28 +08:00
|
|
|
const isMac = isMacLike();
|
|
|
|
for (let [name, def] of commands.entries()) {
|
|
|
|
options.push({
|
|
|
|
name: name,
|
|
|
|
hint: isMac && def.command.mac ? def.command.mac : def.command.key,
|
2022-05-16 21:09:36 +08:00
|
|
|
orderId: recentCommands.has(name)
|
|
|
|
? -recentCommands.get(name)!.getTime()
|
|
|
|
: 0,
|
2022-03-20 16:56:28 +08:00
|
|
|
});
|
|
|
|
}
|
|
|
|
return (
|
|
|
|
<FilterList
|
|
|
|
label="Run"
|
|
|
|
placeholder="Command"
|
|
|
|
options={options}
|
|
|
|
allowNew={false}
|
|
|
|
icon={faPersonRunning}
|
|
|
|
helpText="Start typing the command name to filter results, press <code>Return</code> to run."
|
|
|
|
onSelect={(opt) => {
|
|
|
|
if (opt) {
|
|
|
|
onTrigger(commands.get(opt.name));
|
|
|
|
} else {
|
|
|
|
onTrigger(undefined);
|
|
|
|
}
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
}
|