import type { RequestInstance, ExtractResponseType, ExtractErrorType, CacheValueType } from "@hyper-fetch/core"; import type { isEqual } from "utils"; import type { UseTrackedStateActions, UseTrackedStateType } from "helpers"; export type UseCacheOptionsType = { /** * If `true` it will rerender only when values used by our component gets changed. Otherwise it will rerender on any change. */ dependencyTracking?: boolean; /** * If cache is empty we can use placeholder data. */ initialResponse?: CacheValueType, ExtractErrorType>["data"] | null; /** * Deep comparison function for hook to check for equality in incoming data, to limit rerenders. */ deepCompare?: boolean | typeof isEqual; }; export type UseCacheReturnType = UseTrackedStateType & UseTrackedStateActions & { /** * Invalidate cache for the current request or pass custom key to trigger it by invalidationKey(Regex / cacheKey). */ invalidate: (cacheKeys?: string | RegExp | RequestInstance | Array) => void; };