({
setActiveProject,
}: {
setActiveProject: React.Dispatch<React.SetStateAction<string | null>>
})
| 5 | import Spinner from './Spinner' |
| 6 | |
| 7 | export default function Projects({ |
| 8 | setActiveProject, |
| 9 | }: { |
| 10 | setActiveProject: React.Dispatch<React.SetStateAction<string | null>> |
| 11 | }) { |
| 12 | const queryClient = useQueryClient() |
| 13 | const { data, isFetching } = useSuspenseQuery({ |
| 14 | queryKey: ['projects'], |
| 15 | queryFn: fetchProjects, |
| 16 | }) |
| 17 | |
| 18 | return ( |
| 19 | <div> |
| 20 | <h1>TanStack Repositories {isFetching ? <Spinner /> : null}</h1> |
| 21 | {data.map((project) => ( |
| 22 | <p key={project.full_name}> |
| 23 | <Button |
| 24 | onClick={() => { |
| 25 | // Prefetch the project query |
| 26 | queryClient.prefetchQuery({ |
| 27 | queryKey: ['project', project.full_name], |
| 28 | queryFn: () => fetchProject(project.full_name), |
| 29 | }) |
| 30 | setActiveProject(project.full_name) |
| 31 | }} |
| 32 | > |
| 33 | Load |
| 34 | </Button>{' '} |
| 35 | {project.name} |
| 36 | </p> |
| 37 | ))} |
| 38 | </div> |
| 39 | ) |
| 40 | } |
nothing calls this directly
no test coverage detected
searching dependent graphs…