react-query
Version:
Hooks for managing, caching and syncing asynchronous and remote data in React
34 lines (33 loc) • 1.49 kB
TypeScript
import { CancelOptions, NetworkMode } from './types';
interface RetryerConfig<TData = unknown, TError = unknown> {
fn: () => TData | Promise<TData>;
abort?: () => void;
onError?: (error: TError) => void;
onSuccess?: (data: TData) => void;
onFail?: (failureCount: number, error: TError) => void;
onPause?: () => void;
onContinue?: () => void;
retry?: RetryValue<TError>;
retryDelay?: RetryDelayValue<TError>;
networkMode: NetworkMode | undefined;
}
export interface Retryer<TData = unknown> {
promise: Promise<TData>;
cancel: (cancelOptions?: CancelOptions) => void;
continue: () => void;
cancelRetry: () => void;
continueRetry: () => void;
}
export declare type RetryValue<TError> = boolean | number | ShouldRetryFunction<TError>;
declare type ShouldRetryFunction<TError> = (failureCount: number, error: TError) => boolean;
export declare type RetryDelayValue<TError> = number | RetryDelayFunction<TError>;
declare type RetryDelayFunction<TError = unknown> = (failureCount: number, error: TError) => number;
export declare function canFetch(networkMode: NetworkMode | undefined): boolean;
export declare class CancelledError {
revert?: boolean;
silent?: boolean;
constructor(options?: CancelOptions);
}
export declare function isCancelledError(value: any): value is CancelledError;
export declare function createRetryer<TData = unknown, TError = unknown>(config: RetryerConfig<TData, TError>): Retryer<TData>;
export {};