1.4.0 • Published 3 months ago
@labdigital/graphql-fetcher v1.4.0
@labdigital/graphql-fetcher
Opinionated fetch
wrappers for our client and server side queries in our Next.js frontends.
Only used for fetching from GraphQL endpoints.
Features
- GraphQL support using
TypedDocumentString
as the query - Persisted queries support using either pregenerated hashes or on the fly hashing
- Fallback when persisted query fails
- Client fetcher with React context support when the endpoint is only known at runtime
- Next data cache support
Usage
import { initClientFetcher } from "@labdigital/graphql-fetcher";
const fetcher = initClientFetcher("https://localhost/graphql");
const gqlResponse = await fetcher(query, {
myVar: "baz",
}, {
signal: AbortSignal.timeout(10),
headers: {
"X-extra-header": "foo",
}
});
Notes
Node 18.x requires webcrypto on globalThis
From node 20.x onwards the WebCrypto API is available on globalThis, versions before 20.x will need a small polyfill:
if (typeof window === "undefined" && !globalThis.crypto) {
globalThis.crypto = require("node:crypto").webcrypto;
}