ColumnList() — supabase Function Reference
Architecture documentation for the ColumnList() function in ColumnList.tsx from the supabase codebase.
Entity Profile
Relationship Graph
Source Code
apps/studio/components/interfaces/Database/Tables/ColumnList.tsx lines 38–222
export const ColumnList = ({
onAddColumn = noop,
onEditColumn = noop,
onDeleteColumn = noop,
}: ColumnListProps) => {
const { id: _id, ref } = useParams()
const id = _id ? Number(_id) : undefined
const { data: project } = useSelectedProjectQuery()
const {
data: selectedTable,
error,
isError,
isPending: isLoading,
isSuccess,
} = useTableEditorQuery({
projectRef: project?.ref,
connectionString: project?.connectionString,
id,
})
const [filterString, setFilterString] = useState<string>('')
const isTableEntity = isTableLike(selectedTable)
const columns =
(filterString.length === 0
? selectedTable?.columns ?? []
: selectedTable?.columns?.filter((column) => column.name.includes(filterString))) ?? []
const { isSchemaLocked } = useIsProtectedSchema({ schema: selectedTable?.schema ?? '' })
const { can: canUpdateColumns } = useAsyncCheckPermissions(
PermissionAction.TENANT_SQL_ADMIN_WRITE,
'columns'
)
return (
<div className="space-y-4">
<div className="flex items-center justify-between">
<div className="flex items-center space-x-4">
<Button asChild type="outline" icon={<ChevronLeft />} style={{ padding: '5px' }}>
<Link href={`/project/${ref}/database/tables`} />
</Button>
<Input
size="small"
placeholder="Filter columns"
value={filterString}
onChange={(e: any) => setFilterString(e.target.value)}
icon={<Search />}
/>
</div>
{!isSchemaLocked && isTableEntity && (
<ButtonTooltip
icon={<Plus />}
disabled={!canUpdateColumns}
onClick={() => onAddColumn()}
tooltip={{
content: {
side: 'bottom',
text: !canUpdateColumns
? 'You need additional permissions to create columns'
: undefined,
},
}}
>
New column
</ButtonTooltip>
)}
</div>
{isSchemaLocked && (
<ProtectedSchemaWarning schema={selectedTable?.schema ?? ''} entity="columns" />
)}
{isLoading && <GenericSkeletonLoader />}
{isError && (
<AlertError
error={error as any}
subject={`Failed to retrieve columns for table "${selectedTable?.schema}.${selectedTable?.name}"`}
/>
)}
{isSuccess && (
<>
{columns.length === 0 ? (
<NoSearchResults
searchString={filterString}
onResetFilter={() => setFilterString('')}
/>
) : (
<div>
<Table
head={[
<Table.th key="name">Name</Table.th>,
<Table.th key="description" className="hidden lg:table-cell">
Description
</Table.th>,
<Table.th key="type">Data Type</Table.th>,
<Table.th key="format">Format</Table.th>,
<Table.th key="format" className="text-center">
Nullable
</Table.th>,
<Table.th key="buttons"></Table.th>,
]}
body={columns.map((x) => (
<Table.tr className="border-t" key={x.name}>
<Table.td>
<p>{x.name}</p>
</Table.td>
<Table.td className="break-all whitespace-normal hidden xl:table-cell">
{x.comment !== null ? (
<p title={x.comment}>{x.comment}</p>
) : (
<p className="text-border-stronger">No description</p>
)}
</Table.td>
<Table.td>
<code className="text-code-inline">{x.data_type}</code>
</Table.td>
<Table.td className="font-mono text-xs">
<code className="text-code-inline">{x.format}</code>
</Table.td>
<Table.td className="font-mono text-xs">
{x.is_nullable ? (
<Check size={16} className="mx-auto" />
) : (
<X size={16} className="mx-auto" />
)}
</Table.td>
<Table.td className="text-right">
{!isSchemaLocked && isTableEntity && (
<DropdownMenu>
<DropdownMenuTrigger asChild>
<Button type="default" className="px-1" icon={<MoreVertical />} />
</DropdownMenuTrigger>
<DropdownMenuContent side="bottom" align="end" className="w-32">
<Tooltip>
<TooltipTrigger>
<DropdownMenuItem
disabled={!canUpdateColumns}
onClick={() => onEditColumn(x)}
className="space-x-2"
>
<Edit size={12} />
<p>Edit column</p>
</DropdownMenuItem>
</TooltipTrigger>
{!canUpdateColumns && (
<TooltipContent side="bottom">
Additional permissions required to edit column
</TooltipContent>
)}
</Tooltip>
<Tooltip>
<TooltipTrigger>
<DropdownMenuItem
disabled={!canUpdateColumns || isSchemaLocked}
onClick={() => onDeleteColumn(x)}
className="space-x-2"
>
<Trash stroke="red" size={12} />
<p>Delete column</p>
</DropdownMenuItem>
</TooltipTrigger>
{!canUpdateColumns && (
<TooltipContent side="bottom">
Additional permissions required to delete column
</TooltipContent>
)}
</Tooltip>
</DropdownMenuContent>
</DropdownMenu>
)}
</Table.td>
</Table.tr>
))}
/>
</div>
)}
</>
)}
</div>
)
}
Domain
Subdomains
Source
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free