DiskCountdownRadial() — supabase Function Reference
Architecture documentation for the DiskCountdownRadial() function in DiskCountdownRadial.tsx from the supabase codebase.
Entity Profile
Relationship Graph
Source Code
apps/studio/components/interfaces/DiskManagement/ui/DiskCountdownRadial.tsx lines 12–71
export function DiskCountdownRadial() {
const { ref } = useParams()
const [remainingTime, setRemainingTime] = useState(0)
const {
remainingDuration: initialRemainingTime,
error,
isSuccess,
} = useRemainingDurationForDiskAttributeUpdate({
projectRef: ref,
})
const progressPercentage = (remainingTime / COOLDOWN_DURATION) * 100
useEffect(() => {
if (initialRemainingTime > 0) setRemainingTime(initialRemainingTime)
}, [initialRemainingTime])
useEffect(() => {
if (remainingTime <= 0) return
const timer = setInterval(() => {
setRemainingTime(Math.max(0, remainingTime - 1))
}, 1000)
return () => clearInterval(timer)
}, [remainingTime])
return (
<AnimatePresence>
{remainingTime > 0 && isSuccess && (
<motion.div
initial={{ opacity: 0, height: 0 }}
animate={{ opacity: 1, height: 'auto' }}
exit={{ opacity: 0, height: 0 }}
transition={{ duration: 0.2 }}
>
<Card className="px-2 rounded bg-surface-100">
<CardContent className="py-3 flex gap-3 px-3 items-start">
<CountdownTimerRadial progress={progressPercentage} />
<div className="flex flex-col gap-2">
<div>
<p className="text-foreground text-sm p-0">
6-hour cooldown period is in progress
</p>
<p className="text-foreground-lighter text-sm p-0">
You can't modify your disk configuration again until the 6-hour cool down period
ends.
</p>
</div>
<CountdownTimerSpan seconds={remainingTime} />
</div>
</CardContent>
</Card>
</motion.div>
)}
{error && <FormMessage message={error.message} type="error" />}
</AnimatePresence>
)
}
Domain
Subdomains
Source
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free