2022-05-15 07:01:08 +00:00
|
|
|
import {
|
|
|
|
MutationCache,
|
|
|
|
MutationOptions,
|
|
|
|
QueryCache,
|
|
|
|
QueryClient,
|
|
|
|
QueryKey,
|
|
|
|
QueryOptions,
|
|
|
|
} from 'react-query';
|
|
|
|
|
|
|
|
import { notifyError } from '@/portainer/services/notifications';
|
|
|
|
|
|
|
|
export function withError(fallbackMessage?: string, title = 'Failure') {
|
|
|
|
return {
|
|
|
|
onError(error: unknown) {
|
|
|
|
notifyError(title, error as Error, fallbackMessage);
|
|
|
|
},
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export function withGlobalError(fallbackMessage?: string, title = 'Failure') {
|
|
|
|
return {
|
|
|
|
meta: {
|
|
|
|
error: { message: fallbackMessage, title },
|
|
|
|
},
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
type OptionalReadonly<T> = T | Readonly<T>;
|
|
|
|
|
|
|
|
export function withInvalidate(
|
|
|
|
queryClient: QueryClient,
|
2023-09-04 19:24:41 +00:00
|
|
|
queryKeysToInvalidate: Array<OptionalReadonly<Array<string | number>>>
|
2022-05-15 07:01:08 +00:00
|
|
|
) {
|
|
|
|
return {
|
|
|
|
onSuccess() {
|
2022-05-23 14:32:51 +00:00
|
|
|
return Promise.all(
|
|
|
|
queryKeysToInvalidate.map((keys) => queryClient.invalidateQueries(keys))
|
2022-05-15 07:01:08 +00:00
|
|
|
);
|
|
|
|
},
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export function mutationOptions<
|
|
|
|
TData = unknown,
|
|
|
|
TError = unknown,
|
|
|
|
TVariables = void,
|
2023-09-04 15:20:36 +00:00
|
|
|
TContext = unknown,
|
2022-05-15 07:01:08 +00:00
|
|
|
>(...options: MutationOptions<TData, TError, TVariables, TContext>[]) {
|
|
|
|
return mergeOptions(options);
|
|
|
|
}
|
|
|
|
|
|
|
|
export function queryOptions<
|
|
|
|
TQueryFnData = unknown,
|
|
|
|
TError = unknown,
|
|
|
|
TData = TQueryFnData,
|
2023-09-04 15:20:36 +00:00
|
|
|
TQueryKey extends QueryKey = QueryKey,
|
2022-05-15 07:01:08 +00:00
|
|
|
>(...options: QueryOptions<TQueryFnData, TError, TData, TQueryKey>[]) {
|
|
|
|
return mergeOptions(options);
|
|
|
|
}
|
|
|
|
|
2022-05-23 14:32:51 +00:00
|
|
|
function mergeOptions<T>(options: T[]) {
|
2022-05-15 07:01:08 +00:00
|
|
|
return options.reduce(
|
|
|
|
(acc, option) => ({
|
|
|
|
...acc,
|
|
|
|
...option,
|
|
|
|
}),
|
2023-05-14 09:24:37 +00:00
|
|
|
{} as T
|
2022-05-15 07:01:08 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
export function createQueryClient() {
|
|
|
|
return new QueryClient({
|
|
|
|
mutationCache: new MutationCache({
|
|
|
|
onError: (error, variable, context, mutation) => {
|
|
|
|
handleError(error, mutation.meta?.error);
|
|
|
|
},
|
|
|
|
}),
|
|
|
|
queryCache: new QueryCache({
|
|
|
|
onError: (error, mutation) => {
|
|
|
|
handleError(error, mutation.meta?.error);
|
|
|
|
},
|
|
|
|
}),
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function handleError(error: unknown, errorMeta?: unknown) {
|
|
|
|
if (errorMeta && typeof errorMeta === 'object') {
|
|
|
|
const { title = 'Failure', message } = errorMeta as {
|
|
|
|
title?: string;
|
|
|
|
message?: string;
|
|
|
|
};
|
|
|
|
|
|
|
|
notifyError(title, error as Error, message);
|
|
|
|
}
|
|
|
|
}
|
2022-09-20 18:14:24 +00:00
|
|
|
|
|
|
|
export const queryClient = createQueryClient();
|