@labdigital/graphql-fetcher
TypeScript icon, indicating that this package has built-in type declarations

2.0.0 • Public • Published

@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;
	}

/@labdigital/graphql-fetcher/

    Package Sidebar

    Install

    npm i @labdigital/graphql-fetcher

    Weekly Downloads

    751

    Version

    2.0.0

    License

    MIT

    Unpacked Size

    148 kB

    Total Files

    24

    Last publish

    Collaborators

    • pimvernooij
    • mvantellingen
    • korsvanloon
    • blurrah
    • bramkaashoek