Files
goodgo-platform/apps/web/lib/hooks/use-subscription.ts
Ho Ngoc Hai 9d120dd21f feat(web): add React Query, dark mode toggle, and error retry UX
- Install @tanstack/react-query with exponential backoff retry config
- Create QueryClientProvider and custom hooks for listings, analytics,
  payments, and subscription API calls
- Migrate 5 dashboard pages from useState/useEffect to React Query hooks
- Add dark mode CSS variables and ThemeProvider with localStorage persistence
- Add theme toggle button in dashboard header (sun/moon icon)
- Enhance error boundaries with auto-retry, retry count, and loading state

Co-Authored-By: Paperclip <noreply@paperclip.ing>
2026-04-08 23:02:44 +07:00

32 lines
865 B
TypeScript

import { useQuery } from '@tanstack/react-query';
import { subscriptionApi } from '@/lib/subscription-api';
export const subscriptionKeys = {
all: ['subscription'] as const,
plans: () => ['subscription', 'plans'] as const,
billing: () => ['subscription', 'billing'] as const,
quota: (metric: string) => ['subscription', 'quota', metric] as const,
};
export function usePlans() {
return useQuery({
queryKey: subscriptionKeys.plans(),
queryFn: () => subscriptionApi.getPlans(),
});
}
export function useBillingHistory() {
return useQuery({
queryKey: subscriptionKeys.billing(),
queryFn: () => subscriptionApi.getBillingHistory(),
});
}
export function useQuota(metric: string) {
return useQuery({
queryKey: subscriptionKeys.quota(metric),
queryFn: () => subscriptionApi.checkQuota(metric),
enabled: !!metric,
});
}