mirror of
https://github.com/supabase/supabase.git
synced 2026-06-17 21:23:59 +08:00
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.
87 lines
2.9 KiB
TypeScript
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>
|
|
)
|
|
}
|