2025-01-23 19:41:31 +03:00
|
|
|
import { useQuery, useSuspenseQuery } from '@tanstack/react-query';
|
|
|
|
|
2025-01-29 23:18:08 +03:00
|
|
|
import { queryClient } from '@/backend/queryClient';
|
2025-02-10 01:32:16 +03:00
|
|
|
import { useAuthSuspense } from '@/features/auth/backend/useAuth';
|
2025-01-29 23:18:08 +03:00
|
|
|
import { usePreferencesStore } from '@/stores/preferences';
|
2025-01-27 15:50:15 +03:00
|
|
|
|
2025-01-23 19:41:31 +03:00
|
|
|
import { libraryApi } from './api';
|
|
|
|
|
|
|
|
export function useLibrarySuspense() {
|
2025-01-29 23:18:08 +03:00
|
|
|
const adminMode = usePreferencesStore(state => state.adminMode);
|
2025-01-23 19:41:31 +03:00
|
|
|
const { user } = useAuthSuspense();
|
|
|
|
const { data: items } = useSuspenseQuery({
|
2025-01-29 23:18:08 +03:00
|
|
|
...libraryApi.getLibraryQueryOptions({ isAdmin: user.is_staff && adminMode })
|
2025-01-23 19:41:31 +03:00
|
|
|
});
|
|
|
|
return { items };
|
|
|
|
}
|
|
|
|
|
|
|
|
export function useLibrary() {
|
2025-01-29 23:18:08 +03:00
|
|
|
const adminMode = usePreferencesStore(state => state.adminMode);
|
2025-01-23 19:41:31 +03:00
|
|
|
const { user } = useAuthSuspense();
|
|
|
|
const { data: items, isLoading } = useQuery({
|
2025-01-29 23:18:08 +03:00
|
|
|
...libraryApi.getLibraryQueryOptions({ isAdmin: user.is_staff && adminMode })
|
2025-01-23 19:41:31 +03:00
|
|
|
});
|
|
|
|
return { items: items ?? [], isLoading };
|
|
|
|
}
|
2025-01-29 23:18:08 +03:00
|
|
|
|
|
|
|
export function prefetchLibrary() {
|
|
|
|
return queryClient.prefetchQuery(libraryApi.getLibraryQueryOptions({ isAdmin: false }));
|
|
|
|
}
|