Files
Homarr/src/hooks/widgets/dashDot/api.ts

157 lines
4.1 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';
2023-01-08 14:08:41 +09:00
import type {
2023-01-06 01:11:02 +09:00
UsenetQueueRequestParams,
UsenetQueueResponse,
} from '../../../pages/api/modules/usenet/queue';
2023-01-08 14:08:41 +09:00
import type {
2022-08-26 10:46:34 +02:00
UsenetHistoryRequestParams,
UsenetHistoryResponse,
2022-12-31 16:07:05 +01:00
} from '../../../pages/api/modules/usenet/history';
import { UsenetInfoRequestParams, UsenetInfoResponse } from '../../../pages/api/modules/usenet';
import { UsenetPauseRequestParams } from '../../../pages/api/modules/usenet/pause';
2023-03-17 22:10:00 +01:00
import { queryClient } from '../../../tools/server/configurations/tanstack/queryClient.tool';
2022-12-31 16:07:05 +01:00
import { UsenetResumeRequestParams } from '../../../pages/api/modules/usenet/resume';
2023-06-10 17:20:06 +02:00
import { api } from '~/utils/api';
import { useConfigContext } from '~/config/provider';
2022-08-26 16:12:40 +02:00
2022-08-26 16:43:46 +02:00
const POLLING_INTERVAL = 2000;
2023-06-10 17:20:06 +02:00
export const useGetUsenetInfo = ({ appId }: UsenetInfoRequestParams) => {
const { name: configName } = useConfigContext();
return api.usenet.info.useQuery(
{
appId,
configName: configName!,
},
2022-08-26 16:12:40 +02:00
{
2022-08-26 16:43:46 +02:00
refetchInterval: POLLING_INTERVAL,
2022-08-26 16:12:40 +02:00
keepPreviousData: true,
retry: 2,
2023-06-10 17:20:06 +02:00
enabled: !!appId,
2022-08-26 16:12:40 +02:00
}
);
2023-06-10 17:20:06 +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
},
}
);