ConceptPortal-public/rsconcept/frontend/src/features/library/backend/useLibrary.tsx
Ivan 17b94b5e9a
Some checks are pending
Frontend CI / build (22.x) (push) Waiting to run
R: Refactoring folder structure: introducing features
2025-02-10 01:32:55 +03:00

30 lines
1.0 KiB
TypeScript

import { useQuery, useSuspenseQuery } from '@tanstack/react-query';
import { queryClient } from '@/backend/queryClient';
import { useAuthSuspense } from '@/features/auth/backend/useAuth';
import { usePreferencesStore } from '@/stores/preferences';
import { libraryApi } from './api';
export function useLibrarySuspense() {
const adminMode = usePreferencesStore(state => state.adminMode);
const { user } = useAuthSuspense();
const { data: items } = useSuspenseQuery({
...libraryApi.getLibraryQueryOptions({ isAdmin: user.is_staff && adminMode })
});
return { items };
}
export function useLibrary() {
const adminMode = usePreferencesStore(state => state.adminMode);
const { user } = useAuthSuspense();
const { data: items, isLoading } = useQuery({
...libraryApi.getLibraryQueryOptions({ isAdmin: user.is_staff && adminMode })
});
return { items: items ?? [], isLoading };
}
export function prefetchLibrary() {
return queryClient.prefetchQuery(libraryApi.getLibraryQueryOptions({ isAdmin: false }));
}