23 lines
842 B
TypeScript
23 lines
842 B
TypeScript
import { Api } from '@jellyfin/sdk';
|
|
import { useQuery } from '@tanstack/react-query';
|
|
import { useApi } from 'hooks/useApi';
|
|
import { getChannelsApi } from '@jellyfin/sdk/lib/utils/api/channels-api';
|
|
import { ChannelsApiGetChannelsRequest } from '@jellyfin/sdk/lib/generated-client/api/channels-api';
|
|
import type { AxiosRequestConfig } from 'axios';
|
|
|
|
const fetchChannels = async (api: Api, params?: ChannelsApiGetChannelsRequest, options?: AxiosRequestConfig) => {
|
|
const response = await getChannelsApi(api).getChannels(params, options);
|
|
|
|
return response.data;
|
|
};
|
|
|
|
export const useChannels = (params?: ChannelsApiGetChannelsRequest) => {
|
|
const { api } = useApi();
|
|
|
|
return useQuery({
|
|
queryKey: [ 'Channels' ],
|
|
queryFn: ({ signal }) => fetchChannels(api!, params, { signal }),
|
|
enabled: !!api
|
|
});
|
|
};
|