Files
mtdb_movie/resources/client/user-lists/requests/use-current-user-watchlist.ts
maher 703f50a09d
Some checks failed
Build / run (push) Has been cancelled
first commit
2025-10-29 11:42:25 +01:00

40 lines
1.1 KiB
TypeScript
Executable File

import {useQuery} from '@tanstack/react-query';
import {apiClient} from '@common/http/query-client';
import {BackendResponse} from '@common/http/backend-response/backend-response';
import {useAuth} from '@common/auth/use-auth';
import {Title} from '@app/titles/models/title';
import {Episode} from '@app/titles/models/episode';
interface Response extends BackendResponse {
watchlist: {
id: number;
items: {
title: Record<number, boolean>;
episode: Record<number, boolean>;
};
};
}
export function useCurrentUserWatchlist() {
const {user} = useAuth();
return useQuery({
queryKey: ['channel', 'watchlist', 'compact'],
queryFn: () => fetchWatchlist(),
enabled: !!user,
});
}
export function useIsItemWatchlisted(item: Title | Episode) {
const query = useCurrentUserWatchlist();
return {
isLoading: query.isLoading && query.fetchStatus !== 'idle',
isWatchlisted: !!query.data?.watchlist?.items[item.model_type]?.[item.id],
};
}
function fetchWatchlist() {
return apiClient
.get<Response>(`users/me/watchlist`)
.then(response => response.data);
}