Files
supabase/apps/studio/data/database/view-definition-query.ts
Alaister Young 8e47d317fa chore: pg-meta functions (#26881)
* 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
2024-06-03 23:21:19 +08:00

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,
}
)
}