mirror of
https://github.com/pacnpal/thrilltrack-explorer.git
synced 2025-12-20 15:31:13 -05:00
39 lines
1.1 KiB
TypeScript
39 lines
1.1 KiB
TypeScript
import { useQuery } from '@tanstack/react-query';
|
|
import { supabase } from '@/lib/supabaseClient';
|
|
import { queryKeys } from '@/lib/queryKeys';
|
|
|
|
/**
|
|
* Hook to fetch reviews for a specific entity (park or ride)
|
|
*/
|
|
export function useEntityReviews(entityType: 'park' | 'ride', entityId: string | undefined, enabled = true) {
|
|
return useQuery({
|
|
queryKey: queryKeys.reviews.entity(entityType, entityId || ''),
|
|
queryFn: async () => {
|
|
if (!entityId) return [];
|
|
|
|
const query = supabase
|
|
.from('reviews')
|
|
.select(`
|
|
*,
|
|
profiles!reviews_user_id_fkey(username, avatar_url, display_name)
|
|
`)
|
|
.eq('moderation_status', 'approved')
|
|
.order('created_at', { ascending: false });
|
|
|
|
if (entityType === 'park') {
|
|
query.eq('park_id', entityId);
|
|
} else {
|
|
query.eq('ride_id', entityId);
|
|
}
|
|
|
|
const { data, error } = await query;
|
|
if (error) throw error;
|
|
return data || [];
|
|
},
|
|
enabled: enabled && !!entityId,
|
|
staleTime: 3 * 60 * 1000, // 3 minutes
|
|
gcTime: 10 * 60 * 1000,
|
|
refetchOnWindowFocus: false,
|
|
});
|
|
}
|