import { useQuery } from '@tanstack/react-query'; import type { WebsocketRequest } from '@yaakapp-internal/models'; import type { CallWebsocketRequestActionRequest, GetWebsocketRequestActionsResponse, WebsocketRequestAction, } from '@yaakapp-internal/plugins'; import { useMemo } from 'react'; import { invokeCmd } from '../lib/tauri'; import { usePluginsKey } from './usePlugins'; export type CallableWebSocketRequestAction = Pick & { call: (request: WebsocketRequest) => Promise; }; export function useWebsocketRequestActions() { const pluginsKey = usePluginsKey(); const actionsResult = useQuery({ queryKey: ['websocket_request_actions', pluginsKey], queryFn: () => getWebsocketRequestActions(), }); // biome-ignore lint/correctness/useExhaustiveDependencies: none const actions = useMemo(() => { return actionsResult.data ?? []; }, [JSON.stringify(actionsResult.data)]); return actions; } export async function getWebsocketRequestActions() { const responses = await invokeCmd( 'cmd_websocket_request_actions', ); const actions = responses.flatMap((r) => r.actions.map((a: WebsocketRequestAction, i: number) => ({ label: a.label, icon: a.icon, call: async (websocketRequest: WebsocketRequest) => { const payload: CallWebsocketRequestActionRequest = { index: i, pluginRefId: r.pluginRefId, args: { websocketRequest }, }; await invokeCmd('cmd_call_websocket_request_action', { req: payload }); }, })), ); return actions; }