Files
yaak/src-web/hooks/useWorkspaceActions.ts
Gregory Schier b4a1c418bb Run oxfmt across repo, add format script and docs
Add .oxfmtignore to skip generated bindings and wasm-pack output.
Add npm format script, update DEVELOPMENT.md for Vite+ toolchain,
and format all non-generated files with oxfmt.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-03-13 10:15:49 -07:00

51 lines
1.5 KiB
TypeScript

import { useQuery } from "@tanstack/react-query";
import type { Workspace } from "@yaakapp-internal/models";
import type {
CallWorkspaceActionRequest,
GetWorkspaceActionsResponse,
WorkspaceAction,
} from "@yaakapp-internal/plugins";
import { useMemo } from "react";
import { invokeCmd } from "../lib/tauri";
import { usePluginsKey } from "./usePlugins";
export type CallableWorkspaceAction = Pick<WorkspaceAction, "label" | "icon"> & {
call: (workspace: Workspace) => Promise<void>;
};
export function useWorkspaceActions() {
const pluginsKey = usePluginsKey();
const actionsResult = useQuery<CallableWorkspaceAction[]>({
queryKey: ["workspace_actions", pluginsKey],
queryFn: () => getWorkspaceActions(),
});
// oxlint-disable-next-line react-hooks/exhaustive-deps
const actions = useMemo(() => {
return actionsResult.data ?? [];
}, [JSON.stringify(actionsResult.data)]);
return actions;
}
export async function getWorkspaceActions() {
const responses = await invokeCmd<GetWorkspaceActionsResponse[]>("cmd_workspace_actions");
const actions = responses.flatMap((r) =>
r.actions.map((a, i) => ({
label: a.label,
icon: a.icon,
call: async (workspace: Workspace) => {
const payload: CallWorkspaceActionRequest = {
index: i,
pluginRefId: r.pluginRefId,
args: { workspace },
};
await invokeCmd("cmd_call_workspace_action", { req: payload });
},
})),
);
return actions;
}