react-doctor/query-no-rest-destructuring

Destructure only the fields you need: `const { data, isLoading } = useQuery(...)` — rest destructuring subscribes to all fields and causes extra re-renders

  • Category: TanStack Query
  • Severity: warn
  • Source: oxlint-plugin-react-doctor
  • Framework: tanstack-query
  • Enabled when: framework=tanstack-query and capabilities=tanstack-query

Validation prompt

Use this to decide whether a fired diagnostic is real or a false positive.

Fires on const { ...rest } = useQuery|useInfiniteQuery|useSuspenseQuery|useSuspenseInfiniteQuery(...) where the destructuring ObjectPattern contains a RestElement. React Query tracks which fields a component actually reads and only re-renders when those change; rest subscribes to every observed field, defeating the optimization.

Fix prompt

Use this once validation confirms the diagnostic is real.

Destructure only what you actually read: const { data, isLoading, error } = useQuery(...). If you need to forward every field downstream, pass the result object directly instead of spreading. Plain named destructuring (without ...rest) is fine — the rule only flags the rest element. https://tanstack.com/query/latest/docs/framework/react/guides/render-optimizations