ReadReplicaRow() — supabase Function Reference
Architecture documentation for the ReadReplicaRow() function in ReadReplicaRow.tsx from the supabase codebase.
Entity Profile
Dependency Diagram
graph TD 51db4f53_58c2_7ad8_2211_ae5a7c3efd62["ReadReplicaRow()"] a0154dcb_190a_86d1_30aa_19335df1fc1d["getIsInTransition()"] 51db4f53_58c2_7ad8_2211_ae5a7c3efd62 -->|calls| a0154dcb_190a_86d1_30aa_19335df1fc1d f7db62c8_5925_c885_746c_cdc119199d8a["getStatusLabel()"] 51db4f53_58c2_7ad8_2211_ae5a7c3efd62 -->|calls| f7db62c8_5925_c885_746c_cdc119199d8a style 51db4f53_58c2_7ad8_2211_ae5a7c3efd62 fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
apps/studio/components/interfaces/Database/Replication/ReadReplicas/ReadReplicaRow.tsx lines 36–160
export const ReadReplicaRow = ({ replica, onUpdateReplica }: ReadReplicaRow) => {
const { ref } = useParams()
const { identifier, region, status } = replica
const formattedId = formatDatabaseID(identifier ?? '')
const {
data: lagDuration,
isPending: isLoadingLag,
isError: isErrorLag,
} = useReplicationLagQuery(
{
id: identifier,
projectRef: ref,
connectionString: replica.connectionString,
},
{ enabled: status === REPLICA_STATUS.ACTIVE_HEALTHY }
)
const [showConfirmRestart, setShowConfirmRestart] = useState(false)
const [showConfirmDrop, setShowConfirmDrop] = useState(false)
const regionMeta = Object.values(AWS_REGIONS).find((x) => x.code === region)
const isInTransition = useMemo(() => getIsInTransition({ status }), [status])
const statusLabel = useMemo(() => getStatusLabel({ status }), [status])
return (
<>
<TableRow>
<TableCell>
<DatabaseIcon size={18} className="text-foreground-light" />
</TableCell>
<TableCell>
<div>
<p>Read Replica (ID: {formattedId})</p>
<Tooltip>
<TooltipTrigger asChild>
<p className="text-foreground-lighter w-fit">{regionMeta?.displayName}</p>
</TooltipTrigger>
<TooltipContent side="right">{regionMeta?.code}</TooltipContent>
</Tooltip>
</div>
</TableCell>
<TableCell>
<div className="flex items-center gap-x-2">
<Badge
variant={
statusLabel === 'Healthy'
? 'success'
: statusLabel === 'Failed'
? 'destructive'
: 'default'
}
>
{statusLabel}
</Badge>
{isInTransition && <Loader2 className="animate-spin w-3 h-3" />}
</div>
</TableCell>
<TableCell>
{isErrorLag || status !== REPLICA_STATUS.ACTIVE_HEALTHY ? (
<Minus size={18} className="text-foreground-lighter" />
) : isLoadingLag ? (
<ShimmeringLoader />
) : (
<p>{lagDuration}s</p>
)}
</TableCell>
<TableCell>
<Minus size={18} className="text-foreground-lighter" />
</TableCell>
<TableCell>
<div className="flex items-center justify-end gap-x-2">
<Button asChild type="default" className="relative" disabled={status === 'GOING_DOWN'}>
<Link href={`/project/${ref}/database/replication/replica/${replica.identifier}`}>
View replication
</Link>
</Button>
<DropdownMenu>
<DropdownMenuTrigger>
<Button type="default" icon={<MoreVertical />} className="w-7" />
</DropdownMenuTrigger>
<DropdownMenuContent align="end" className="w-52">
<DropdownMenuItem
className="gap-x-2"
disabled={status !== 'ACTIVE_HEALTHY'}
onClick={() => setShowConfirmRestart(true)}
>
<RotateCcw size={14} />
<span>Restart replica</span>
</DropdownMenuItem>
<DropdownMenuSeparator />
<DropdownMenuItem
className="gap-x-2"
disabled={status === 'GOING_DOWN'}
onClick={() => setShowConfirmDrop(true)}
>
<Trash size={14} />
<span>Drop replica</span>
</DropdownMenuItem>
</DropdownMenuContent>
</DropdownMenu>
</div>
</TableCell>
</TableRow>
<DropReplicaConfirmationModal
selectedReplica={showConfirmDrop ? replica : undefined}
onSuccess={() => onUpdateReplica()}
onCancel={() => setShowConfirmDrop(false)}
/>
<RestartReplicaConfirmationModal
selectedReplica={showConfirmRestart ? replica : undefined}
onSuccess={() => onUpdateReplica()}
onCancel={() => setShowConfirmRestart(false)}
/>
</>
)
}
Domain
Subdomains
Source
Frequently Asked Questions
What does ReadReplicaRow() do?
ReadReplicaRow() is a function in the supabase codebase.
What does ReadReplicaRow() call?
ReadReplicaRow() calls 2 function(s): getIsInTransition, getStatusLabel.
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free