mirror of
https://github.com/supabase/supabase.git
synced 2026-07-04 03:54:29 +08:00
* start pg-meta functions * pg meta create function * pg meta database functions update and delete * fix ts * update execute sql error type * update execute sql error type * remove duplicate database functions query
45 lines
1.2 KiB
TypeScript
45 lines
1.2 KiB
TypeScript
import { UseQueryOptions } from '@tanstack/react-query'
|
|
import { ExecuteSqlData, ExecuteSqlError, useExecuteSqlQuery } from '../sql/execute-sql-query'
|
|
|
|
type GetViewDefinition = {
|
|
schema?: string
|
|
name?: string
|
|
}
|
|
|
|
export const getViewDefinitionQuery = ({ schema, name }: GetViewDefinition) => {
|
|
const sql = /* SQL */ `
|
|
select pg_get_viewdef(to_regclass('"${schema}"."${name}"'), true) as definition
|
|
`.trim()
|
|
|
|
return sql
|
|
}
|
|
|
|
export type ViewDefinitionVariables = GetViewDefinition & {
|
|
projectRef?: string
|
|
connectionString?: string
|
|
}
|
|
|
|
export type ViewDefinitionData = string
|
|
export type ViewDefinitionError = ExecuteSqlError
|
|
|
|
export const useViewDefinitionQuery = <TData extends ViewDefinitionData = ViewDefinitionData>(
|
|
{ projectRef, connectionString, schema, name }: ViewDefinitionVariables,
|
|
options: UseQueryOptions<ExecuteSqlData, ViewDefinitionError, TData> = {}
|
|
) => {
|
|
return useExecuteSqlQuery(
|
|
{
|
|
projectRef,
|
|
connectionString,
|
|
sql: getViewDefinitionQuery({ schema, name }),
|
|
queryKey: ['view-definition', schema, name],
|
|
},
|
|
{
|
|
select(data) {
|
|
return data.result[0].definition.trim()
|
|
},
|
|
enabled: typeof schema !== 'undefined' && typeof name !== 'undefined',
|
|
...options,
|
|
}
|
|
)
|
|
}
|