mirror of
https://github.com/jellyfin/jellyfin-web
synced 2025-03-30 19:56:21 +00:00
38 lines
1 KiB
TypeScript
38 lines
1 KiB
TypeScript
import type { DevicesApiGetDevicesRequest } from '@jellyfin/sdk/lib/generated-client';
|
|
import type { AxiosRequestConfig } from 'axios';
|
|
import type { Api } from '@jellyfin/sdk';
|
|
import { getDevicesApi } from '@jellyfin/sdk/lib/utils/api/devices-api';
|
|
import { useQuery } from '@tanstack/react-query';
|
|
|
|
import { useApi } from 'hooks/useApi';
|
|
|
|
export const QUERY_KEY = 'Devices';
|
|
|
|
const fetchDevices = async (
|
|
api?: Api,
|
|
requestParams?: DevicesApiGetDevicesRequest,
|
|
options?: AxiosRequestConfig
|
|
) => {
|
|
if (!api) {
|
|
console.warn('[fetchDevices] No API instance available');
|
|
return;
|
|
}
|
|
|
|
const response = await getDevicesApi(api).getDevices(requestParams, {
|
|
signal: options?.signal
|
|
});
|
|
|
|
return response.data;
|
|
};
|
|
|
|
export const useDevices = (
|
|
requestParams: DevicesApiGetDevicesRequest
|
|
) => {
|
|
const { api } = useApi();
|
|
return useQuery({
|
|
queryKey: [QUERY_KEY, requestParams],
|
|
queryFn: ({ signal }) =>
|
|
fetchDevices(api, requestParams, { signal }),
|
|
enabled: !!api
|
|
});
|
|
};
|