mirror of
https://github.com/supabase/supabase.git
synced 2026-05-07 01:10:15 -04:00
f2122b64f2
* Use paginated projects endpoint for docs * Deprecate old projects query * Fix * Fix * fix(docs branch selector) * refactor(docs project selector): simplify dom --------- Co-authored-by: Charis Lam <26616127+charislam@users.noreply.github.com>
87 lines
2.7 KiB
TypeScript
87 lines
2.7 KiB
TypeScript
import { useInfiniteQuery, UseInfiniteQueryOptions } from '@tanstack/react-query'
|
|
import { components } from 'api-types'
|
|
import type { ResponseError } from '~/types/fetch'
|
|
import { get } from './fetchWrappers'
|
|
|
|
const DEFAULT_LIMIT = 10
|
|
const projectKeys = {
|
|
listInfinite: (params?: {
|
|
limit: number
|
|
sort?: 'name_asc' | 'name_desc' | 'created_asc' | 'created_desc'
|
|
search?: string
|
|
}) => ['all-projects-infinite', params].filter(Boolean),
|
|
}
|
|
|
|
interface GetProjectsInfiniteVariables {
|
|
limit?: number
|
|
sort?: 'name_asc' | 'name_desc' | 'created_asc' | 'created_desc'
|
|
search?: string
|
|
page?: number
|
|
}
|
|
|
|
export type ProjectInfoInfinite =
|
|
components['schemas']['ListProjectsPaginatedResponse']['projects'][number]
|
|
|
|
async function getProjects(
|
|
{
|
|
limit = DEFAULT_LIMIT,
|
|
page = 0,
|
|
sort = 'name_asc',
|
|
search: _search = '',
|
|
}: GetProjectsInfiniteVariables,
|
|
signal?: AbortSignal,
|
|
headers?: Record<string, string>
|
|
) {
|
|
const offset = page * limit
|
|
const search = _search.length === 0 ? undefined : _search
|
|
|
|
const { data, error } = await get('/platform/projects', {
|
|
// @ts-ignore [Joshen] API type issue for Version 2 endpoints
|
|
params: { query: { limit, offset, sort, search } },
|
|
signal,
|
|
headers: { ...headers, Version: '2' },
|
|
})
|
|
|
|
if (error) throw error
|
|
return data as unknown as components['schemas']['ListProjectsPaginatedResponse']
|
|
}
|
|
|
|
export type ProjectsInfiniteData = Awaited<ReturnType<typeof getProjects>>
|
|
export type ProjectsInfiniteError = ResponseError
|
|
|
|
export const useProjectsInfiniteQuery = <
|
|
TData = { pages: ProjectsInfiniteData[]; pageParams: number[] },
|
|
>(
|
|
{ limit = DEFAULT_LIMIT, sort = 'name_asc', search }: GetProjectsInfiniteVariables,
|
|
{
|
|
enabled = true,
|
|
...options
|
|
}: Omit<
|
|
UseInfiniteQueryOptions<ProjectsInfiniteData, ProjectsInfiniteError, TData>,
|
|
'queryKey' | 'getNextPageParam' | 'initialPageParam'
|
|
>
|
|
) => {
|
|
return useInfiniteQuery<ProjectsInfiniteData, ProjectsInfiniteError, TData>({
|
|
enabled,
|
|
queryKey: projectKeys.listInfinite({ limit, sort, search }),
|
|
queryFn: ({ signal, pageParam }) =>
|
|
getProjects({ limit, page: pageParam as any, sort, search }, signal),
|
|
initialPageParam: 0,
|
|
getNextPageParam(lastPage, pages) {
|
|
const page = pages.length
|
|
const currentTotalCount = page * limit
|
|
// @ts-ignore [Joshen] API type issue for Version 2 endpoints
|
|
const totalCount = lastPage.pagination.count
|
|
|
|
if (currentTotalCount >= totalCount) return undefined
|
|
return page
|
|
},
|
|
staleTime: 30 * 60 * 1000, // 30 minutes
|
|
...options,
|
|
})
|
|
}
|
|
|
|
export function isProjectPaused(project: { status: string } | null): boolean | undefined {
|
|
return !project ? undefined : project.status === 'INACTIVE'
|
|
}
|