Files
Homarr/src/hooks/api.ts

155 lines
4.0 KiB
TypeScript
Raw Normal View History

2022-08-26 16:12:40 +02:00
import { useMutation, useQuery } from '@tanstack/react-query';
2022-08-25 21:07:41 +02:00
import axios from 'axios';
2022-08-26 16:12:40 +02:00
import { Results } from 'sabnzbd-api';
import {
UsenetQueueRequestParams,
UsenetQueueResponse,
2022-12-23 17:29:58 +01:00
} from '../pages/api/modules/usenet/queue';
2022-08-26 10:46:34 +02:00
import {
UsenetHistoryRequestParams,
UsenetHistoryResponse,
2022-12-23 17:29:58 +01:00
} from '../pages/api/modules/usenet/history';
import { UsenetInfoRequestParams, UsenetInfoResponse } from '../pages/api/modules/usenet';
import { UsenetPauseRequestParams } from '../pages/api/modules/usenet/pause';
import { queryClient } from '../tools/queryClient';
import { UsenetResumeRequestParams } from '../pages/api/modules/usenet/resume';
2022-08-26 16:12:40 +02:00
2022-08-26 16:43:46 +02:00
const POLLING_INTERVAL = 2000;
2022-08-26 16:12:40 +02:00
export const useGetUsenetInfo = (params: UsenetInfoRequestParams) =>
useQuery(
['usenetInfo', params.appId],
2022-08-26 16:12:40 +02:00
async () =>
(
await axios.get<UsenetInfoResponse>('/api/modules/usenet', {
params,
})
).data,
{
2022-08-26 16:43:46 +02:00
refetchInterval: POLLING_INTERVAL,
2022-08-26 16:12:40 +02:00
keepPreviousData: true,
retry: 2,
enabled: !!params.appId,
2022-08-26 16:12:40 +02:00
}
);
2022-08-25 21:07:41 +02:00
2022-08-26 10:46:34 +02:00
export const useGetUsenetDownloads = (params: UsenetQueueRequestParams) =>
2022-08-25 21:07:41 +02:00
useQuery(
2022-08-26 10:46:34 +02:00
['usenetDownloads', ...Object.values(params)],
async () =>
(
2022-08-26 16:12:40 +02:00
await axios.get<UsenetQueueResponse>('/api/modules/usenet/queue', {
2022-08-26 10:46:34 +02:00
params,
})
).data,
2022-08-25 21:07:41 +02:00
{
2022-08-26 16:43:46 +02:00
refetchInterval: POLLING_INTERVAL,
2022-08-26 10:46:34 +02:00
keepPreviousData: true,
2022-08-26 11:10:40 +02:00
retry: 2,
2022-08-25 21:07:41 +02:00
}
);
2022-08-26 10:46:34 +02:00
export const useGetUsenetHistory = (params: UsenetHistoryRequestParams) =>
2022-08-25 21:07:41 +02:00
useQuery(
2022-08-26 10:46:34 +02:00
['usenetHistory', ...Object.values(params)],
async () =>
(
await axios.get<UsenetHistoryResponse>('/api/modules/usenet/history', {
params,
})
).data,
2022-08-25 21:07:41 +02:00
{
2022-08-26 16:43:46 +02:00
refetchInterval: POLLING_INTERVAL,
2022-08-26 10:46:34 +02:00
keepPreviousData: true,
2022-08-26 11:10:40 +02:00
retry: 2,
2022-08-25 21:07:41 +02:00
}
);
2022-08-26 16:12:40 +02:00
export const usePauseUsenetQueue = (params: UsenetPauseRequestParams) =>
useMutation(
['usenetPause', ...Object.values(params)],
async () =>
(
await axios.post<Results>(
'/api/modules/usenet/pause',
{},
{
params,
}
)
).data,
{
async onMutate() {
await queryClient.cancelQueries(['usenetInfo', params.appId]);
2022-08-26 16:12:40 +02:00
const previousInfo = queryClient.getQueryData<UsenetInfoResponse>([
'usenetInfo',
params.appId,
2022-08-26 16:12:40 +02:00
]);
if (previousInfo) {
queryClient.setQueryData<UsenetInfoResponse>(['usenetInfo', params.appId], {
2022-08-26 16:12:40 +02:00
...previousInfo,
paused: true,
});
}
return { previousInfo };
},
onError(err, _, context) {
if (context?.previousInfo) {
queryClient.setQueryData<UsenetInfoResponse>(
['usenetInfo', params.appId],
2022-08-26 16:12:40 +02:00
context.previousInfo
);
}
},
onSettled() {
queryClient.invalidateQueries(['usenetInfo', params.appId]);
2022-08-26 16:12:40 +02:00
},
}
);
export const useResumeUsenetQueue = (params: UsenetResumeRequestParams) =>
useMutation(
['usenetResume', ...Object.values(params)],
async () =>
(
await axios.post<Results>(
'/api/modules/usenet/resume',
{},
{
params,
}
)
).data,
{
async onMutate() {
await queryClient.cancelQueries(['usenetInfo', params.appId]);
2022-08-26 16:12:40 +02:00
const previousInfo = queryClient.getQueryData<UsenetInfoResponse>([
'usenetInfo',
params.appId,
2022-08-26 16:12:40 +02:00
]);
if (previousInfo) {
queryClient.setQueryData<UsenetInfoResponse>(['usenetInfo', params.appId], {
2022-08-26 16:12:40 +02:00
...previousInfo,
paused: false,
});
}
return { previousInfo };
},
onError(err, _, context) {
if (context?.previousInfo) {
queryClient.setQueryData<UsenetInfoResponse>(
['usenetInfo', params.appId],
2022-08-26 16:12:40 +02:00
context.previousInfo
);
}
},
onSettled() {
queryClient.invalidateQueries(['usenetInfo', params.appId]);
2022-08-26 16:12:40 +02:00
},
}
);