mirror of
https://github.com/usebruno/bruno.git
synced 2025-01-08 23:18:54 +01:00
44 lines
1.1 KiB
JavaScript
44 lines
1.1 KiB
JavaScript
import { useState, useEffect } from 'react';
|
|
import { getIntrospectionQuery, buildClientSchema } from 'graphql';
|
|
|
|
const useGraphqlSchema =(endpoint) => {
|
|
const [isLoaded, setIsLoaded] = useState(false);
|
|
const [schema, setSchema] = useState(null);
|
|
const [error, setError] = useState(null);
|
|
|
|
const introspectionQuery = getIntrospectionQuery();
|
|
const queryParams = {
|
|
query: introspectionQuery
|
|
}
|
|
|
|
useEffect(() => {
|
|
fetch(endpoint, {
|
|
method: "POST",
|
|
headers: {
|
|
'Accept': 'application/json',
|
|
'Content-Type': 'application/json'
|
|
},
|
|
body: JSON.stringify(queryParams)
|
|
})
|
|
.then((res) => res.json())
|
|
.then((s) => {
|
|
if(s && s.data) {
|
|
setSchema(buildClientSchema(s.data));
|
|
setIsLoaded(true);
|
|
} else {
|
|
return Promise.reject(new Error('An error occurred while introspecting schema'));
|
|
}
|
|
})
|
|
.catch((err) => {
|
|
setError(err);
|
|
});
|
|
}, []);
|
|
|
|
return {
|
|
isLoaded,
|
|
schema,
|
|
error
|
|
};
|
|
}
|
|
|
|
export default useGraphqlSchema; |