mango-ui-v2/components/ResetLayout.tsx

43 lines
1.2 KiB
TypeScript

import { useEffect, useState } from 'react'
import { RefreshClockwiseIcon } from './icons'
import { defaultLayouts } from './TradePageGrid'
import useLocalStorageState from '../hooks/useLocalStorageState'
import Tooltip from './Tooltip'
const ResetLayout = ({ className = '' }) => {
const [spin, setSpin] = useState(false)
const [, setSavedLayouts] = useLocalStorageState(
'savedLayouts',
defaultLayouts
)
useEffect(() => {
const timer = setTimeout(() => {
setSpin(false)
}, 500)
return () => clearTimeout(timer)
}, [spin])
const handleResetLayout = () => {
setSavedLayouts(defaultLayouts)
setSpin(true)
}
return (
<div className={`flex relative ${className} mr-4`}>
<Tooltip content="Reset Layout" className="text-xs py-1">
<button
onClick={() => handleResetLayout()}
className="flex items-center justify-center rounded-full bg-th-bkg-3 w-8 h-8 hover:text-th-primary focus:outline-none"
>
<RefreshClockwiseIcon
className={`w-5 h-5 ${spin ? 'animate-spin' : null}`}
/>
</button>
</Tooltip>
</div>
)
}
export default ResetLayout