mirror of
https://github.com/mountain-loop/yaak.git
synced 2026-01-15 21:53:36 +01:00
51 lines
1.5 KiB
TypeScript
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(),
|
|
});
|
|
|
|
// biome-ignore lint/correctness/useExhaustiveDependencies: none
|
|
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;
|
|
}
|