Better schema fetching

This commit is contained in:
Gregory Schier
2023-03-31 16:02:09 -07:00
parent 3e8a10757f
commit 42e2c9f96f
2 changed files with 9 additions and 3 deletions

View File

@@ -60,12 +60,13 @@ export function GraphQLEditor({ defaultValue, onChange, baseRequest, ...extraEdi
const editorViewRef = useRef<EditorView>(null); const editorViewRef = useRef<EditorView>(null);
useEffect(() => { useEffect(() => {
let unmounted = false;
const body = JSON.stringify({ const body = JSON.stringify({
query: getIntrospectionQuery(), query: getIntrospectionQuery(),
operationName: 'IntrospectionQuery', operationName: 'IntrospectionQuery',
}); });
const req: HttpRequest = { ...baseRequest, body, id: '' }; sendEphemeralRequest({ ...baseRequest, body }).then((response) => {
sendEphemeralRequest(req).then((response) => { if (unmounted) return;
try { try {
if (editorViewRef.current) { if (editorViewRef.current) {
const { data } = JSON.parse(response.body); const { data } = JSON.parse(response.body);
@@ -77,6 +78,9 @@ export function GraphQLEditor({ defaultValue, onChange, baseRequest, ...extraEdi
return; return;
} }
}); });
return () => {
unmounted = true;
};
}, [baseRequest.url]); }, [baseRequest.url]);
return ( return (

View File

@@ -2,5 +2,7 @@ import { invoke } from '@tauri-apps/api';
import type { HttpRequest, HttpResponse } from './models'; import type { HttpRequest, HttpResponse } from './models';
export function sendEphemeralRequest(request: HttpRequest): Promise<HttpResponse> { export function sendEphemeralRequest(request: HttpRequest): Promise<HttpResponse> {
return invoke('send_ephemeral_request', { request }); // Ensure it's not associated with an ID
const newRequest = { ...request, id: '' };
return invoke('send_ephemeral_request', { request: newRequest });
} }