mango-ui-v3/components/ResetLayout.tsx

38 lines
1.0 KiB
TypeScript
Raw Normal View History

2021-04-22 06:10:43 -07:00
import { useEffect, useState } from 'react'
import { RefreshIcon } from '@heroicons/react/outline'
import { defaultLayouts } from './TradePageGrid'
import useLocalStorageState from '../hooks/useLocalStorageState'
const ResetLayout = ({ className = '' }) => {
2021-04-22 06:10:43 -07:00
const [spin, setSpin] = useState(false)
const [, setSavedLayouts] = useLocalStorageState(
'savedLayouts',
defaultLayouts
)
2021-04-22 06:10:43 -07:00
useEffect(() => {
const timer = setTimeout(() => {
setSpin(false)
}, 500)
return () => clearTimeout(timer)
}, [spin])
const handleResetLayout = () => {
setSavedLayouts(defaultLayouts)
setSpin(true)
}
return (
<div className={`flex relative ${className}`}>
<button
2021-04-22 06:10:43 -07:00
onClick={() => handleResetLayout()}
className="flex items-center justify-center rounded-full bg-th-bkg-3 w-8 h-8 mr-4 hover:text-th-primary focus:outline-none"
>
2021-04-22 06:10:43 -07:00
<RefreshIcon className={`w-5 h-5 ${spin ? 'animate-spin' : null}`} />
</button>
</div>
)
}
export default ResetLayout