mango-v4-ui/components/account/ActivityFeed.tsx

131 lines
4.3 KiB
TypeScript
Raw Normal View History

2022-09-27 23:17:06 -07:00
import { IconButton } from '@components/shared/Button'
import { ArrowLeftIcon } from '@heroicons/react/20/solid'
2022-09-28 06:04:58 -07:00
import mangoStore, { LiquidationFeedItem } from '@store/mangoStore'
2022-09-26 23:22:51 -07:00
import dayjs from 'dayjs'
2022-09-27 23:17:06 -07:00
import useLocalStorageState from 'hooks/useLocalStorageState'
2022-09-26 23:22:51 -07:00
import { useTranslation } from 'next-i18next'
2022-09-27 23:17:06 -07:00
import Image from 'next/image'
import { EXPLORERS } from 'pages/settings'
import { useState } from 'react'
import { PREFERRED_EXPLORER_KEY } from 'utils/constants'
import { formatDecimal, formatFixedDecimals } from 'utils/numbers'
import ActivityFeedTable from './ActivityFeedTable'
2022-09-26 23:22:51 -07:00
const ActivityFeed = () => {
const activityFeed = mangoStore((s) => s.activityFeed.feed)
const loadActivityFeed = mangoStore((s) => s.activityFeed.loading)
2022-09-27 23:17:06 -07:00
const [showActivityDetail, setShowActivityDetail] = useState(null)
2022-09-26 23:22:51 -07:00
2022-09-27 23:17:06 -07:00
const handleShowActivityDetails = (activity: any) => {
setShowActivityDetail(activity)
}
2022-09-26 23:22:51 -07:00
2022-09-27 23:17:06 -07:00
return !showActivityDetail ? (
<ActivityFeedTable
activityFeed={activityFeed}
handleShowActivityDetails={handleShowActivityDetails}
/>
) : (
<ActivityDetails
activity={showActivityDetail}
setShowActivityDetail={setShowActivityDetail}
/>
2022-09-26 23:22:51 -07:00
)
}
export default ActivityFeed
2022-09-27 23:17:06 -07:00
const ActivityDetails = ({
activity,
setShowActivityDetail,
}: {
activity: LiquidationFeedItem
setShowActivityDetail: (x: any) => void
}) => {
2022-09-28 06:04:58 -07:00
const { t } = useTranslation(['common', 'activity', 'settings'])
2022-09-27 23:17:06 -07:00
const [preferredExplorer] = useLocalStorageState(
PREFERRED_EXPLORER_KEY,
EXPLORERS[0]
)
const { block_datetime } = activity
const {
asset_amount,
asset_price,
asset_symbol,
liab_amount,
liab_price,
liab_symbol,
signature,
} = activity.activity_details
return (
<div>
<div className="flex items-center p-6">
<IconButton
className="mr-4"
onClick={() => setShowActivityDetail(null)}
>
<ArrowLeftIcon className="h-5 w-5" />
</IconButton>
2022-09-28 06:04:58 -07:00
<h2 className="text-lg">{t('activity:liquidation-details')}</h2>
2022-09-27 23:17:06 -07:00
</div>
2022-09-28 06:04:58 -07:00
<div className="grid grid-cols-1 gap-4 px-6 lg:grid-cols-3">
2022-09-27 23:17:06 -07:00
<div className="col-span-1">
<p className="mb-0.5 text-sm">{t('date')}</p>
<p className="text-th-fgd-1">
{dayjs(block_datetime).format('ddd D MMM')}
</p>
<p className="text-xs text-th-fgd-3">
{dayjs(block_datetime).format('h:mma')}
</p>
</div>
<div className="col-span-1">
<p className="mb-0.5 text-sm">{t('activity:asset-liquidated')}</p>
2022-09-28 06:04:58 -07:00
<p className="font-mono text-th-fgd-1">
{formatDecimal(asset_amount)}{' '}
<span className="font-body tracking-wide">{asset_symbol}</span>
<span className="ml-2 font-body tracking-wide text-th-fgd-3">
at
</span>{' '}
{formatFixedDecimals(asset_price, true)}
2022-09-27 23:17:06 -07:00
</p>
2022-09-28 06:04:58 -07:00
<p className="font-mono text-xs text-th-fgd-3">
2022-09-27 23:17:06 -07:00
{formatFixedDecimals(asset_price * asset_amount, true)}
</p>
</div>
<div className="col-span-1">
<p className="mb-0.5 text-sm">{t('activity:asset-returned')}</p>
2022-09-28 06:04:58 -07:00
<p className="font-mono text-th-fgd-1">
{formatDecimal(liab_amount)}{' '}
<span className="font-body tracking-wide">{liab_symbol}</span>
<span className="ml-2 font-body tracking-wide text-th-fgd-3">
at
</span>{' '}
{formatFixedDecimals(liab_price, true)}
2022-09-27 23:17:06 -07:00
</p>
2022-09-28 06:04:58 -07:00
<p className="font-mono text-xs text-th-fgd-3">
2022-09-27 23:17:06 -07:00
{formatFixedDecimals(liab_price * liab_amount, true)}
</p>
</div>
</div>
<div className="col-span-3 mt-8 flex justify-center border-y border-th-bkg-3 py-3">
<a
className="default-transition flex items-center text-th-fgd-1 hover:text-th-fgd-3"
href={`${preferredExplorer.url}${signature}`}
target="_blank"
rel="noopener noreferrer"
>
<Image
alt=""
width="20"
height="20"
src={`/explorer-logos/${preferredExplorer.name}.png`}
/>
<span className="ml-2 text-base">{`View on ${t(
`settings:${preferredExplorer.name}`
)}`}</span>
</a>
</div>
</div>
)
}