useSuspenseQuery(...)
See the useSuspenseQuery(...) ๐ด documentation.
The Hook enables you to perform asynchronous data fetching operations, similar to useQuery Hook, but with the added benefit of Suspense support. See the TanStack useSuspenseQuery(...) ๐ด documentation for more details.
const result = api.<service>.<operation>.useSuspenseQuery(
parameters,
queryOptions
)
Argumentsโ
-
parameters: { path, query, header } | QueryKey | void
- Required only if OpenAPI specification defines required parameters
- If the operation has no required parameters according to OpenAPI, you can omit this argument
parameters
will be used to generate theQueryKey
- Instead of an object with
{path, query, header}
, you can pass aQueryKey
as an array which is also strictly-typed โจ - If operation does not require parameters, you must pass an empty object
{}
for strictness
-
queryOptions?: UseQueryOptions
- Optional, represents the options of the useSuspenseQuery(...) ๐ด Hook
queryOptions.queryFn
could be provided to override the defaultqueryFn
used by Qraft
- Optional, represents the options of the useSuspenseQuery(...) ๐ด Hook
Returnsโ
TData
- the result from the query
Exampleโ
src/ApprovalPolicyName.tsx
import { Suspense } from 'react';
import { createAPIClient } from './api'; // generated by OpenAPI Qraft CLI
import { requestFn } from '@openapi-qraft/react';
import { QueryClient, QueryClientProvider } from '@tanstack/react-query';
const queryClient = new QueryClient();
const api = createAPIClient({
requestFn,
queryClient,
baseUrl: 'https://api.sandbox.monite.com/v1',
});
function ApprovalPolicyName() {
/**
* `<service>.<operation>.useSuspenseQuery(...)` initiates
* the request for data retrieval:
* ###
* GET /approval_policies/321?items_order=asc&items_order=desc
* x-monite-version: 1.0.0
*/
const approvalPolicy =
api.approvalPolicies.getApprovalPoliciesId.useSuspenseQuery(
{
header: {
"x-monite-version": "1.0.0",
},
path: {
approval_policy_id: "123",
},
query: {
items_order: ["asc", "desc"],
},
},
);
return <div>Approval Policy: {approvalPolicy.name}</div>;
}
export default function() {
return (
<QueryClientProvider client={queryClient}>
<Suspense fallback={<div>Loading...</div>}>
<ApprovalPolicyName />
</Suspense>
</QueryClientProvider>
);
}