Files
supabase/apps/studio/components/interfaces/DiskManagement/ui/DiskManagementCoolDownSection.tsx
Ivan Vasilov 308cd791a2 chore: Prep work for migrating to Tailwind v4 (#45285)
This PR preps the monorepo for a migration to Tailwind v4:
- Bump all Tailwind dependencies and libraries to the latest possible
version, while still compatible with Tailwind 3.
- Cleans up obsolete Tailwind 3 specific options and configs.
- Cleans up unused CSS files and fixes the CSS imports.
- Migrates all `important` uses in `@apply` lines to using the `!`
prefix.
- Move `typography.css` to the `config` package and import it from the
apps.
- Migrated all occurrences of `flex-grow`, `flex-shrink`,
`overflow-clip` and `overflow-ellipsis` since they're deprecated and
will be removed in Tailwind 4.
- Make the default theme object typesafe in the `ui` package.
- Migrate all `bg-opacity`, `border-opacity`, `ring-opacity` and
`divider-opacity` to the new format where they're declared as part of
the property color.
- Bump and unify all imports of `postcss` dependency.
2026-04-28 11:33:53 +02:00

87 lines
2.9 KiB
TypeScript

import { AnimatePresence, motion } from 'framer-motion'
import { useEffect, useState } from 'react'
import { DialogSection } from 'ui'
import CountdownTimerRadial from '@/components/ui/CountdownTimer/CountdownTimerRadial'
export const DiskMangementCoolDownSection = ({ visible }: { visible: boolean }) => {
const [progress, setProgress] = useState(100)
const [showCountdown, setShowCountdown] = useState(false)
const [isJumping, setIsJumping] = useState(false)
useEffect(() => {
const startCountdown = () => {
setShowCountdown(true)
setProgress(100)
const interval = setInterval(() => {
setProgress((prevProgress) => {
if (prevProgress <= 0) {
clearInterval(interval)
setIsJumping(true)
setTimeout(() => {
setIsJumping(false)
setProgress(100)
startCountdown() // Restart the countdown
}, 300) // Duration of the jump animation
return 0
}
return prevProgress - 1
})
}, 100)
return () => clearInterval(interval)
}
const initialDelay = setTimeout(startCountdown, 1000)
return () => clearTimeout(initialDelay)
}, [])
return (
<AnimatePresence>
{visible && (
<motion.div
initial={{ opacity: 1, height: 'auto' }}
exit={{ opacity: 0, height: 0 }}
transition={{ duration: 0.15 }}
className="w-full"
>
<DialogSection className="bg-surface-100 text-sm text-foreground-light flex items-center gap-4 relative w-full border rounded-md">
<div className="w-12 h-12">
<AnimatePresence>
{showCountdown && (
<motion.div
key="countdown-timer"
initial={{ scale: 0.8, opacity: 0, y: -8 }}
animate={{
scale: isJumping ? 1.2 : 1,
opacity: 1,
y: isJumping ? -8 : 0,
}}
exit={{ scale: 0.8, opacity: 0, y: -8 }}
transition={{
duration: isJumping ? 0.3 : 0.8,
type: 'spring',
bounce: 0.6,
}}
>
<CountdownTimerRadial progress={progress} />
</motion.div>
)}
</AnimatePresence>
</div>
<div className="flex flex-col gap-0 grow">
<p className="text-sm text-foreground">
For 4 hours you will not be able to change any disk attributes.
</p>
<p className="text-sm text-foreground-light">
There is a cooldown period enforced for any disk attribute modifications
</p>
</div>
</DialogSection>
</motion.div>
)}
</AnimatePresence>
)
}