When a bill page opens with no stored articles, the backend queues a fetch_news_for_bill Celery task and returns immediately. Added a retry loop (up to 3x, 6 s apart) driven off newsArticles state so articles populate without a manual refresh. Fixed broken useEffect dependency ([billId] → [newsArticles]) that caused the timer to never fire. News is now fetched via a separate useBillNews query (staleTime: 0) independent of the cached bill detail response. Co-Authored-By: Jack Levy
47 lines
1.1 KiB
TypeScript
47 lines
1.1 KiB
TypeScript
import { useQuery } from "@tanstack/react-query";
|
|
import { billsAPI } from "../api";
|
|
|
|
export function useBills(params?: Record<string, unknown>) {
|
|
return useQuery({
|
|
queryKey: ["bills", params],
|
|
queryFn: () => billsAPI.list(params),
|
|
staleTime: 5 * 60 * 1000,
|
|
});
|
|
}
|
|
|
|
export function useBill(id: string) {
|
|
return useQuery({
|
|
queryKey: ["bill", id],
|
|
queryFn: () => billsAPI.get(id),
|
|
staleTime: 2 * 60 * 1000,
|
|
enabled: !!id,
|
|
});
|
|
}
|
|
|
|
export function useBillActions(id: string) {
|
|
return useQuery({
|
|
queryKey: ["bill-actions", id],
|
|
queryFn: () => billsAPI.getActions(id),
|
|
staleTime: 5 * 60 * 1000,
|
|
enabled: !!id,
|
|
});
|
|
}
|
|
|
|
export function useBillNews(id: string) {
|
|
return useQuery({
|
|
queryKey: ["bill-news", id],
|
|
queryFn: () => billsAPI.getNews(id),
|
|
staleTime: 0, // Always fetch fresh — news arrives async after brief generation
|
|
enabled: !!id,
|
|
});
|
|
}
|
|
|
|
export function useBillTrend(id: string, days = 30) {
|
|
return useQuery({
|
|
queryKey: ["bill-trend", id, days],
|
|
queryFn: () => billsAPI.getTrend(id, days),
|
|
staleTime: 60 * 60 * 1000,
|
|
enabled: !!id,
|
|
});
|
|
}
|