import { useQuery } from "@tanstack/react-query"; import type { Folder } from "@yaakapp-internal/models"; import type { CallFolderActionRequest, FolderAction, GetFolderActionsResponse, } from "@yaakapp-internal/plugins"; import { useMemo } from "react"; import { invokeCmd } from "../lib/tauri"; import { usePluginsKey } from "./usePlugins"; export type CallableFolderAction = Pick & { call: (folder: Folder) => Promise; }; export function useFolderActions() { const pluginsKey = usePluginsKey(); const actionsResult = useQuery({ queryKey: ["folder_actions", pluginsKey], queryFn: () => getFolderActions(), }); // oxlint-disable-next-line react-hooks/exhaustive-deps const actions = useMemo(() => { return actionsResult.data ?? []; }, [JSON.stringify(actionsResult.data)]); return actions; } export async function getFolderActions() { const responses = await invokeCmd("cmd_folder_actions"); const actions = responses.flatMap((r) => r.actions.map((a, i) => ({ label: a.label, icon: a.icon, call: async (folder: Folder) => { const payload: CallFolderActionRequest = { index: i, pluginRefId: r.pluginRefId, args: { folder }, }; await invokeCmd("cmd_call_folder_action", { req: payload }); }, })), ); return actions; }