Remove shortcuts again, just trigger command pallete

pull/3/head
Zef Hemel 2022-06-20 18:30:45 +02:00
parent 4ada18a213
commit 94d0e31b30
8 changed files with 29 additions and 110 deletions

View File

@ -123,8 +123,6 @@ functions:
command: command:
name: "Template: Quick Note" name: "Template: Quick Note"
key: "Alt-Shift-n" key: "Alt-Shift-n"
shortcut:
label: "Quick note"
quickTaskCommand: quickTaskCommand:
path: ./template.ts:quickTaskCommand path: ./template.ts:quickTaskCommand
command: command:

View File

@ -10,8 +10,6 @@ functions:
command: command:
name: "Materialized Queries: Update" name: "Materialized Queries: Update"
key: "Alt-q" key: "Alt-q"
shortcut:
label: "Update queries"
events: events:
- editor:pageLoaded - editor:pageLoaded
indexData: indexData:

View File

@ -1,5 +1,6 @@
import { useEffect, useState } from "react"; import { faRunning } from "@fortawesome/free-solid-svg-icons";
import { ShortcutItem, Notification } from "../types"; import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";
import { Notification } from "../types";
function prettyName(s: string | undefined): string { function prettyName(s: string | undefined): string {
if (!s) { if (!s) {
@ -12,33 +13,19 @@ export function TopBar({
pageName, pageName,
unsavedChanges, unsavedChanges,
notifications, notifications,
shortcutItems,
onClick, onClick,
onActionClick,
lhs, lhs,
rhs, rhs,
}: { }: {
pageName?: string; pageName?: string;
unsavedChanges: boolean; unsavedChanges: boolean;
notifications: Notification[]; notifications: Notification[];
shortcutItems: ShortcutItem[];
onClick: () => void; onClick: () => void;
onActionClick: () => void;
lhs?: React.ReactNode; lhs?: React.ReactNode;
rhs?: React.ReactNode; rhs?: React.ReactNode;
}) { }) {
const [menuExpanded, setMenuExpanded] = useState(false);
useEffect(() => {
function closer() {
setMenuExpanded(false);
}
document.addEventListener("click", closer);
return () => {
document.removeEventListener("click", closer);
};
}, []);
return ( return (
<div id="top" onClick={onClick}> <div id="top" onClick={onClick}>
{lhs} {lhs}
@ -59,31 +46,13 @@ export function TopBar({
<div className="actions"> <div className="actions">
<button <button
onClick={(e) => { onClick={(e) => {
setMenuExpanded(!menuExpanded); // setMenuExpanded(!menuExpanded);
onActionClick();
e.stopPropagation(); e.stopPropagation();
}} }}
> >
... <FontAwesomeIcon icon={faRunning} />
</button> </button>
{menuExpanded && (
<ul>
{shortcutItems.map((actionButton, idx) => (
<li key={idx}>
<a
href="#"
onClick={(e) => {
e.preventDefault();
e.stopPropagation();
setMenuExpanded(false);
actionButton.run();
}}
>
{actionButton.label}
</a>
</li>
))}
</ul>
)}
</div> </div>
</div> </div>
</div> </div>

View File

@ -127,11 +127,10 @@ export class Editor {
// Command hook // Command hook
this.commandHook = new CommandHook(); this.commandHook = new CommandHook();
this.commandHook.on({ this.commandHook.on({
commandsUpdated: (commandMap, shortcutItems) => { commandsUpdated: (commandMap) => {
this.viewDispatch({ this.viewDispatch({
type: "update-commands", type: "update-commands",
commands: commandMap, commands: commandMap,
shortcutItems: shortcutItems,
}); });
}, },
}); });
@ -660,7 +659,6 @@ export class Editor {
placeholder={viewState.filterBoxPlaceHolder} placeholder={viewState.filterBoxPlaceHolder}
options={viewState.filterBoxOptions} options={viewState.filterBoxOptions}
allowNew={false} allowNew={false}
// icon={faPersonRunning}
helpText={viewState.filterBoxHelpText} helpText={viewState.filterBoxHelpText}
onSelect={viewState.filterBoxOnSelect} onSelect={viewState.filterBoxOnSelect}
/> />
@ -669,19 +667,12 @@ export class Editor {
pageName={viewState.currentPage} pageName={viewState.currentPage}
notifications={viewState.notifications} notifications={viewState.notifications}
unsavedChanges={viewState.unsavedChanges} unsavedChanges={viewState.unsavedChanges}
shortcutItems={[
{
label: "Run command",
orderId: 0,
run: () => {
this.viewDispatch({ type: "show-palette" });
},
},
...viewState.shortcutItems,
]}
onClick={() => { onClick={() => {
dispatch({ type: "start-navigate" }); dispatch({ type: "start-navigate" });
}} }}
onActionClick={() => {
dispatch({ type: "show-palette" });
}}
rhs={ rhs={
!!viewState.showRHS && ( !!viewState.showRHS && (
<div className="panel" style={{ flex: viewState.showRHS }} /> <div className="panel" style={{ flex: viewState.showRHS }} />

View File

@ -1,7 +1,6 @@
import { Hook, Manifest } from "@plugos/plugos/types"; import { Hook, Manifest } from "@plugos/plugos/types";
import { System } from "@plugos/plugos/system"; import { System } from "@plugos/plugos/system";
import { EventEmitter } from "@plugos/plugos/event"; import { EventEmitter } from "@plugos/plugos/event";
import { ShortcutItem } from "../types";
export type CommandDef = { export type CommandDef = {
name: string; name: string;
@ -11,13 +10,6 @@ export type CommandDef = {
// Bind to keyboard shortcut // Bind to keyboard shortcut
key?: string; key?: string;
mac?: string; mac?: string;
// Shortcuts in UI
shortcut?: ShortcutDef;
};
export type ShortcutDef = {
label: string;
}; };
export type AppCommand = { export type AppCommand = {
@ -30,10 +22,7 @@ export type CommandHookT = {
}; };
export type CommandHookEvents = { export type CommandHookEvents = {
commandsUpdated( commandsUpdated(commandMap: Map<string, AppCommand>): void;
commandMap: Map<string, AppCommand>,
appButtons: ShortcutItem[]
): void;
}; };
export class CommandHook export class CommandHook
@ -41,11 +30,9 @@ export class CommandHook
implements Hook<CommandHookT> implements Hook<CommandHookT>
{ {
editorCommands = new Map<string, AppCommand>(); editorCommands = new Map<string, AppCommand>();
shortcutItems: ShortcutItem[] = [];
buildAllCommands(system: System<CommandHookT>) { buildAllCommands(system: System<CommandHookT>) {
this.editorCommands.clear(); this.editorCommands.clear();
this.shortcutItems = [];
for (let plug of system.loadedPlugs.values()) { for (let plug of system.loadedPlugs.values()) {
for (const [name, functionDef] of Object.entries( for (const [name, functionDef] of Object.entries(
plug.manifest!.functions plug.manifest!.functions
@ -60,17 +47,9 @@ export class CommandHook
return plug.invoke(name, []); return plug.invoke(name, []);
}, },
}); });
if (cmd.shortcut) {
this.shortcutItems.push({
label: cmd.shortcut.label,
run: () => {
return plug.invoke(name, []);
},
});
} }
} }
} this.emit("commandsUpdated", this.editorCommands);
this.emit("commandsUpdated", this.editorCommands, this.shortcutItems);
} }
apply(system: System<CommandHookT>): void { apply(system: System<CommandHookT>): void {

View File

@ -76,7 +76,6 @@ export default function reducer(
return { return {
...state, ...state,
commands: action.commands, commands: action.commands,
shortcutItems: action.shortcutItems,
}; };
case "show-notification": case "show-notification":
return { return {

View File

@ -76,19 +76,19 @@ body {
display: flex; display: flex;
flex-direction: row; flex-direction: row;
// .status { .status {
// position: absolute; position: absolute;
// font-family: "iA-Mono"; font-family: "iA-Mono";
// bottom: 45px; bottom: 45px;
// left: 5px; left: 5px;
// right: 5px; right: 5px;
// background-color: rgb(187, 221, 247); background-color: rgb(187, 221, 247);
// border: rgb(41, 41, 41) 1px solid; border: rgb(41, 41, 41) 1px solid;
// border-radius: 5px; border-radius: 5px;
// padding: 3px; padding: 3px;
// font-size: 15px; font-size: 15px;
// z-index: 100; z-index: 100;
// } }
.current-page { .current-page {
font-family: var(--ui-font); font-family: var(--ui-font);
@ -97,15 +97,11 @@ body {
overflow: hidden; overflow: hidden;
white-space: nowrap; white-space: nowrap;
// margin-right: 40px; text-align: left;
display: block; display: block;
text-overflow: ellipsis;
} }
// .icon {
// padding-left: 5px;
// padding-right: 10px;
// }
.saved { .saved {
color: #111; color: #111;
} }
@ -115,10 +111,8 @@ body {
} }
} }
.actions { .actions {
// float: right;
text-align: right; text-align: right;
width: 40px; width: 40px;
// margin-top: -35px;
ul { ul {
list-style: none; list-style: none;

View File

@ -9,12 +9,6 @@ export type Notification = {
date: Date; date: Date;
}; };
export type ShortcutItem = {
label: string;
orderId?: number;
run: () => void;
};
export type AppViewState = { export type AppViewState = {
currentPage?: string; currentPage?: string;
perm: "ro" | "rw"; perm: "ro" | "rw";
@ -34,7 +28,6 @@ export type AppViewState = {
allPages: Set<PageMeta>; allPages: Set<PageMeta>;
commands: Map<string, AppCommand>; commands: Map<string, AppCommand>;
notifications: Notification[]; notifications: Notification[];
shortcutItems: ShortcutItem[];
recentCommands: Map<string, Date>; recentCommands: Map<string, Date>;
showFilterBox: boolean; showFilterBox: boolean;
@ -60,7 +53,6 @@ export const initialViewState: AppViewState = {
commands: new Map(), commands: new Map(),
recentCommands: new Map(), recentCommands: new Map(),
notifications: [], notifications: [],
shortcutItems: [],
showFilterBox: false, showFilterBox: false,
filterBoxHelpText: "", filterBoxHelpText: "",
filterBoxLabel: "", filterBoxLabel: "",
@ -79,7 +71,6 @@ export type Action =
| { | {
type: "update-commands"; type: "update-commands";
commands: Map<string, AppCommand>; commands: Map<string, AppCommand>;
shortcutItems: ShortcutItem[];
} }
| { type: "show-palette"; context?: string } | { type: "show-palette"; context?: string }
| { type: "hide-palette" } | { type: "hide-palette" }