Files
supabase/apps/studio/data/materialized-views/materialized-views-query.ts
Joshen Lim 54320ddb73 Chore/support showing all entities in database tables page (#27749)
* Support showing views in database tables page

* Support showing materialized views in database tables page

* Support showing foreign tables in database tables page

* Prevent deleting non table entities in database/tables, consistent with table editor

* Fix invalidation logic when deleting tables in database/tables
2024-07-03 14:40:45 +08:00

61 lines
1.9 KiB
TypeScript

import { UseQueryOptions, useQuery } from '@tanstack/react-query'
import { PostgresMaterializedView } from '@supabase/postgres-meta'
import { get, handleError } from 'data/fetchers'
import type { ResponseError } from 'types'
import { materializedViewKeys } from './keys'
export type MaterializedViewsVariables = {
projectRef?: string
connectionString?: string
schema?: string
}
export async function getMaterializedViews(
{ projectRef, connectionString, schema }: MaterializedViewsVariables,
signal?: AbortSignal
) {
if (!projectRef) throw new Error('projectRef is required')
let headers = new Headers()
if (connectionString) headers.set('x-connection-encrypted', connectionString)
const { data, error } = await get('/platform/pg-meta/{ref}/materialized-views', {
params: {
header: { 'x-connection-encrypted': connectionString! },
path: { ref: projectRef },
query: {
included_schemas: schema || '',
include_columns: true,
} as any,
},
headers,
signal,
})
if (error) handleError(error)
return data as PostgresMaterializedView[]
}
export type MaterializedViewsData = Awaited<ReturnType<typeof getMaterializedViews>>
export type MaterializedViewsError = ResponseError
export const useMaterializedViewsQuery = <TData = MaterializedViewsData>(
{ projectRef, connectionString, schema }: MaterializedViewsVariables,
{
enabled = true,
...options
}: UseQueryOptions<MaterializedViewsData, MaterializedViewsError, TData> = {}
) =>
useQuery<MaterializedViewsData, MaterializedViewsError, TData>(
schema
? materializedViewKeys.listBySchema(projectRef, schema)
: materializedViewKeys.list(projectRef),
({ signal }) => getMaterializedViews({ projectRef, connectionString, schema }, signal),
{
enabled: enabled && typeof projectRef !== 'undefined',
staleTime: 0,
...options,
}
)