BackupsList() — supabase Function Reference
Architecture documentation for the BackupsList() function in BackupsList.tsx from the supabase codebase.
Entity Profile
Relationship Graph
Source Code
apps/studio/components/interfaces/Database/Backups/BackupsList.tsx lines 23–142
export const BackupsList = () => {
const router = useRouter()
const { ref: projectRef } = useParams()
const [selectedBackup, setSelectedBackup] = useState<DatabaseBackup>()
const { hasAccess: hasAccessToBackups } = useCheckEntitlements('backup.retention_days')
const { setProjectStatus } = useSetProjectStatus()
const { data: selectedProject } = useSelectedProjectQuery()
const isHealthy = selectedProject?.status === PROJECT_STATUS.ACTIVE_HEALTHY
const { data: backups } = useBackupsQuery({ projectRef })
const {
mutate: restoreFromBackup,
isPending: isRestoring,
isSuccess: isSuccessBackup,
} = useBackupRestoreMutation({
onSuccess: () => {
if (projectRef) {
setTimeout(() => {
setProjectStatus({ ref: projectRef, status: PROJECT_STATUS.RESTORING })
toast.success(
`Restoring database back to ${dayjs(selectedBackup?.inserted_at).format(
'DD MMM YYYY HH:mm:ss'
)}`
)
router.push(`/project/${projectRef}`)
}, 3000)
}
},
})
const sortedBackups = (backups?.backups ?? []).sort(
(a, b) => new Date(b.inserted_at).valueOf() - new Date(a.inserted_at).valueOf()
)
const isPitrEnabled = backups?.pitr_enabled
if (!hasAccessToBackups) {
return (
<UpgradeToPro
addon="pitr"
source="backups"
featureProposition="have up to 7 days of scheduled backups"
icon={<Clock size={20} />}
primaryText="Free Plan does not include project backups."
secondaryText="Upgrade to the Pro Plan for up to 7 days of scheduled backups."
buttonText="Upgrade"
/>
)
}
if (isPitrEnabled) return null
return (
<>
<div className="space-y-6">
{sortedBackups.length === 0 ? (
<BackupsEmpty />
) : (
<>
<BackupsStorageAlert />
<Panel>
{sortedBackups?.map((x, i: number) => {
return (
<BackupItem
key={x.id}
backup={x}
index={i}
isHealthy={isHealthy}
onSelectBackup={() => setSelectedBackup(x)}
/>
)
})}
</Panel>
</>
)}
</div>
<ConfirmationModal
size="small"
confirmLabel="Restore"
confirmLabelLoading="Restoring..."
variant="warning"
visible={selectedBackup !== undefined}
title="Restore from backup"
loading={isRestoring || isSuccessBackup}
onCancel={() => setSelectedBackup(undefined)}
onConfirm={() => {
if (projectRef === undefined) return console.error('Project ref required')
if (selectedBackup === undefined) return console.error('Backup required')
restoreFromBackup({ ref: projectRef, backup: selectedBackup })
}}
>
<div className="space-y-3">
{!!selectedBackup && (
<p className="text-sm">
This will restore your database to the backup made on{' '}
<TimestampInfo
displayAs="utc"
utcTimestamp={selectedBackup.inserted_at}
labelFormat="DD MMM YYYY HH:mm:ss (ZZ)"
className="!text-sm"
/>
</p>
)}
<Admonition
showIcon={false}
type="warning"
title="This action cannot be undone"
description={
<ul className="list-disc list-inside">
<li>Your project will be offline during restoration</li>
<li>Any new data since this backup will be lost</li>
</ul>
}
/>
</div>
</ConfirmationModal>
</>
)
}
Domain
Subdomains
Source
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free