Files
supabase/apps/studio/components/interfaces/Settings/Infrastructure/InfrastructureConfiguration/RestartReplicaConfirmationModal.tsx
2026-04-01 10:22:37 +02:00

94 lines
3.3 KiB
TypeScript

import { useQueryClient } from '@tanstack/react-query'
import { useParams } from 'common'
import { toast } from 'sonner'
import ConfirmationModal from 'ui-patterns/Dialogs/ConfirmationModal'
import { REPLICA_STATUS } from './InstanceConfiguration.constants'
import { useProjectRestartMutation } from '@/data/projects/project-restart-mutation'
import { replicaKeys } from '@/data/read-replicas/keys'
import { Database } from '@/data/read-replicas/replicas-query'
import { formatDatabaseID } from '@/data/read-replicas/replicas.utils'
interface RestartReplicaConfirmationModalProps {
selectedReplica?: Database
onSuccess: () => void
onCancel: () => void
}
export const RestartReplicaConfirmationModal = ({
selectedReplica,
onSuccess,
onCancel,
}: RestartReplicaConfirmationModalProps) => {
const { ref } = useParams()
const queryClient = useQueryClient()
const formattedId = formatDatabaseID(selectedReplica?.identifier ?? '')
const { mutate: restartProject, isPending: isRestartingProject } = useProjectRestartMutation({
onSuccess: () => {
toast.success(`Restarting read replica (ID: ${formattedId})`)
// [Joshen] Temporarily optimistic rendering until API supports immediate status update
queryClient.setQueriesData({ queryKey: replicaKeys.list(ref) }, (old: Database[]) => {
const updatedReplicas = old.map((x) => {
if (x.identifier === selectedReplica?.identifier) {
return { ...x, status: REPLICA_STATUS.RESTARTING }
} else {
return x
}
})
return updatedReplicas
})
queryClient.setQueriesData({ queryKey: replicaKeys.statuses(ref) }, (old: Database[]) => {
const updatedReplicas = old.map((x) => {
if (x.identifier === selectedReplica?.identifier) {
return { ...x, status: REPLICA_STATUS.RESTARTING }
} else {
return x
}
})
return updatedReplicas
})
onSuccess()
onCancel()
},
onError: (error) => {
toast.error(`Failed to restart replica: ${error.message}`)
},
})
const onConfirmRestartReplica = () => {
if (!ref) return console.error('Project is required')
if (selectedReplica === undefined) return toast.error('No replica selected')
restartProject({ ref, identifier: selectedReplica.identifier })
}
return (
<ConfirmationModal
size="medium"
variant="warning"
loading={isRestartingProject}
visible={selectedReplica !== undefined}
title={`Confirm to restart selected replica? (ID: ${formattedId})`}
confirmLabel="Restart replica"
confirmLabelLoading="Restarting replica"
onCancel={() => onCancel()}
onConfirm={() => onConfirmRestartReplica()}
>
<p className="text-sm">
Your replica will be offline for a few minutes while it is being restarted. Before
restarting the replica, consider:
</p>
<ul className="text-sm text-foreground-light py-1 list-disc mx-4 space-y-1">
<li>
Network traffic from this region may slow down while the replica is restarting, especially
if you have no other replicas in this region
</li>
</ul>
<p className="text-sm mt-2">Are you sure you want to restart this replica now?</p>
</ConfirmationModal>
)
}