Files
streamyfin/hooks/useItemQuery.ts
2025-11-06 13:15:41 +01:00

47 lines
1.3 KiB
TypeScript

import { getUserLibraryApi } from "@jellyfin/sdk/lib/utils/api";
import { ItemFields } from "@jellyfin/sdk/lib/generated-client/models";
import { useQuery } from "@tanstack/react-query";
import { useAtom } from "jotai";
import { useDownload } from "@/providers/DownloadProvider";
import { apiAtom, userAtom } from "@/providers/JellyfinProvider";
export const DEFAULT_FIELDS_EXCEPT_MEDIA_SOURCES = Object.values(ItemFields).filter(
(field) => field !== ItemFields.MediaSources
);
export const useItem = (
itemId: string | undefined,
isOffline?: boolean
fields?: ItemFields[],
) => {
const [api] = useAtom(apiAtom);
const [user] = useAtom(userAtom);
const { getDownloadedItemById } = useDownload();
return useQuery({
queryKey: ["item", itemId, fields],
queryFn: async () => {
if (!itemId) throw new Error('Item ID is required');
if (isOffline) {
return getDownloadedItemById(itemId)?.item;
}
if (!api || !user) return null;
const response = await getUserLibraryApi(api).getItem({
itemId,
userId: user.Id,
...(fields && { fields }),
});
return response.data;
},
enabled: !!itemId,
staleTime: 0,
refetchOnMount: true,
refetchOnWindowFocus: true,
refetchOnReconnect: true,
networkMode: "always",
});
};