UNPKG

graphql-react

Version:

A GraphQL client for React using modern context and hooks APIs that’s lightweight (< 4 kB) but powerful; the first Relay and Apollo alternative with server side rendering.

40 lines (30 loc) 1.05 kB
// @ts-check import React from "react"; import useCache from "./useCache.mjs"; /** @typedef {import("./Cache.mjs").default} Cache */ /** @typedef {import("./Cache.mjs").CacheEventMap} CacheEventMap */ /** * React hook to prevent a {@link Cache.store cache store} entry from being * pruned, by canceling the cache entry deletion for * {@link CacheEventMap.prune `prune`} events with `event.preventDefault()`. * @param {import("./Cache.mjs").CacheKey} cacheKey Cache key. */ export default function useCacheEntryPrunePrevention(cacheKey) { if (typeof cacheKey !== "string") throw new TypeError("Argument 1 `cacheKey` must be a string."); const cache = useCache(); React.useEffect(() => { const eventNamePrune = `${cacheKey}/prune`; cache.addEventListener(eventNamePrune, cancelEvent); return () => { cache.removeEventListener(eventNamePrune, cancelEvent); }; }, [cache, cacheKey]); } /** * Cancels an event. * @param {Event} event Event. */ function cancelEvent(event) { event.preventDefault(); }