TableIndexAdvisorProvider() — supabase Function Reference
Architecture documentation for the TableIndexAdvisorProvider() function in TableIndexAdvisorContext.tsx from the supabase codebase.
Entity Profile
Relationship Graph
Source Code
apps/studio/components/grid/context/TableIndexAdvisorContext.tsx lines 42–135
export function TableIndexAdvisorProvider({
children,
schema,
table,
}: PropsWithChildren<TableIndexAdvisorProviderProps>) {
const { data: project } = useSelectedProjectQuery()
const { isIndexAdvisorAvailable, isIndexAdvisorEnabled } = useIndexAdvisorStatus()
const queryClient = useQueryClient()
const [isSheetOpen, setIsSheetOpen] = useState(false)
const [selectedColumn, setSelectedColumn] = useState<string | undefined>(undefined)
const { data, isLoading } = useTableIndexAdvisorQuery(
{
projectRef: project?.ref,
connectionString: project?.connectionString,
schema,
table,
},
{
enabled: isIndexAdvisorEnabled && !!schema && !!table,
}
)
const openSheet = useCallback((columnName: string) => {
setSelectedColumn(columnName)
setIsSheetOpen(true)
}, [])
const closeSheet = useCallback(() => {
setIsSheetOpen(false)
setSelectedColumn(undefined)
}, [])
const getSuggestionsForColumn = useCallback(
(columnName: string): IndexAdvisorSuggestion[] => {
if (!data?.suggestions) return []
// Filter suggestions that include this column in their index statements
return data.suggestions.filter((suggestion) =>
suggestion.index_statements.some((stmt) => {
const match = stmt.match(/USING\s+\w+\s*\(([^)]+)\)/i)
if (match) {
const columns = match[1].split(',').map((c) => c.trim().replace(/^"(.+)"$/, '$1'))
return columns.includes(columnName)
}
return false
})
)
},
[data?.suggestions]
)
const invalidate = useCallback(async () => {
if (project?.ref && schema && table) {
await queryClient.invalidateQueries({
queryKey: databaseKeys.tableIndexAdvisor(project.ref, schema, table),
})
}
}, [queryClient, project?.ref, schema, table])
// Get the first suggestion for the selected column to pass to QueryIndexes
const selectedSuggestion = selectedColumn ? getSuggestionsForColumn(selectedColumn)[0] : null
const value: TableIndexAdvisorContextValue = {
isLoading,
isAvailable: isIndexAdvisorAvailable,
isEnabled: isIndexAdvisorEnabled,
columnsWithSuggestions: data?.columnsWithSuggestions ?? [],
suggestions: data?.suggestions ?? [],
openSheet,
getSuggestionsForColumn,
invalidate,
}
return (
<TableIndexAdvisorContext.Provider value={value}>
{children}
<Sheet open={isSheetOpen} onOpenChange={(open) => !open && closeSheet()}>
<SheetContent className="flex flex-col gap-0 p-0 sm:max-w-[500px]">
<SheetHeader className="border-b px-5 py-3">
<SheetTitle>Index Recommendation</SheetTitle>
</SheetHeader>
{selectedSuggestion && (
<QueryIndexes
selectedRow={{ query: selectedSuggestion.query }}
columnName={selectedColumn}
suggestedSelectQuery={selectedSuggestion.query}
onClose={closeSheet}
/>
)}
</SheetContent>
</Sheet>
</TableIndexAdvisorContext.Provider>
)
}
Domain
Subdomains
Source
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free