mirror of
https://github.com/supabase/supabase.git
synced 2026-07-04 07:35:22 +08:00
46 lines
1.2 KiB
TypeScript
46 lines
1.2 KiB
TypeScript
import { UseQueryOptions } from '@tanstack/react-query'
|
|
import { ExecuteSqlData, useExecuteSqlQuery } from '../sql/execute-sql-query'
|
|
|
|
type GetViewDefinition = {
|
|
schema?: string
|
|
name?: string
|
|
}
|
|
|
|
export const getViewDefinitionQuery = ({ schema, name }: GetViewDefinition) => {
|
|
const fullName = [schema, name].filter(Boolean).join('.')
|
|
|
|
const sql = /* SQL */ `
|
|
select pg_get_viewdef('${fullName}', true) as definition
|
|
`.trim()
|
|
|
|
return sql
|
|
}
|
|
|
|
export type ViewDefinitionVariables = GetViewDefinition & {
|
|
projectRef?: string
|
|
connectionString?: string
|
|
}
|
|
|
|
export type ViewDefinitionData = string
|
|
export type ViewDefinitionError = unknown
|
|
|
|
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()
|
|
},
|
|
...options,
|
|
}
|
|
)
|
|
}
|