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

128 lines
3.5 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-06-10 17:25:36 +02:00
import { useConfigContext } from '~/config/provider';
2023-06-10 17:38:57 +02:00
import { RouterInputs, api } from '~/utils/api';
2023-06-10 17:25:36 +02:00
import { UsenetInfoRequestParams, UsenetInfoResponse } from '../../../pages/api/modules/usenet';
import type { UsenetHistoryRequestParams } from '../../../pages/api/modules/usenet/history';
import { UsenetPauseRequestParams } from '../../../pages/api/modules/usenet/pause';
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';
2022-12-31 16:07:05 +01:00
import { UsenetResumeRequestParams } from '../../../pages/api/modules/usenet/resume';
2023-06-10 17:25:36 +02:00
import { queryClient } from '../../../tools/server/configurations/tanstack/queryClient.tool';
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
}
);
2023-06-10 17:25:36 +02:00
export const useGetUsenetHistory = (params: UsenetHistoryRequestParams) => {
const { name: configName } = useConfigContext();
return api.usenet.history.useQuery(
{
configName: configName!,
...params,
},
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
}
);
2023-06-10 17:25:36 +02:00
};
2022-08-26 16:12:40 +02:00
2023-06-10 17:38:57 +02:00
export const usePauseUsenetQueueMutation = (params: UsenetPauseRequestParams) => {
const { name: configName } = useConfigContext();
const { mutateAsync, mutate, ...mutation } = api.usenet.pause.useMutation();
const utils = api.useContext();
return async (variables: Omit<RouterInputs['usenet']['pause'], 'configName'>) => {
await mutateAsync(
{
configName: configName!,
...variables,
2022-08-26 16:12:40 +02:00
},
2023-06-10 17:38:57 +02:00
{
onSettled() {
utils.usenet.info.invalidate({ appId: 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
},
}
);