2022-02-14 09:17:11 -08:00
|
|
|
import { useEffect, useState, useCallback } from 'react'
|
2022-02-14 09:15:28 -08:00
|
|
|
import PageBodyContainer from '../components/PageBodyContainer'
|
|
|
|
import TopBar from '../components/TopBar'
|
|
|
|
import { serverSideTranslations } from 'next-i18next/serverSideTranslations'
|
|
|
|
import useMangoStore from '../stores/useMangoStore'
|
2022-02-14 09:15:46 -08:00
|
|
|
import {
|
2022-02-14 11:21:06 -08:00
|
|
|
mangoCacheSelector,
|
2022-02-14 09:15:46 -08:00
|
|
|
mangoGroupConfigSelector,
|
|
|
|
mangoGroupSelector,
|
2022-03-18 11:41:23 -07:00
|
|
|
walletSelector,
|
2022-02-14 09:15:46 -08:00
|
|
|
} from '../stores/selectors'
|
2022-02-22 15:30:54 -08:00
|
|
|
import Button, { IconButton } from '../components/Button'
|
2022-03-17 09:36:09 -07:00
|
|
|
import {
|
|
|
|
abbreviateAddress,
|
|
|
|
copyToClipboard,
|
|
|
|
formatUsdValue,
|
|
|
|
usdFormatter,
|
|
|
|
} from '../utils'
|
2022-02-14 09:15:46 -08:00
|
|
|
import { notify } from '../utils/notifications'
|
2022-02-14 09:17:11 -08:00
|
|
|
import {
|
|
|
|
getMarketIndexBySymbol,
|
|
|
|
ReferrerIdRecord,
|
|
|
|
} from '@blockworks-foundation/mango-client'
|
2022-02-10 15:48:14 -08:00
|
|
|
import { useTranslation } from 'next-i18next'
|
|
|
|
import EmptyState from '../components/EmptyState'
|
|
|
|
import {
|
|
|
|
CheckIcon,
|
|
|
|
CurrencyDollarIcon,
|
|
|
|
DuplicateIcon,
|
|
|
|
LinkIcon,
|
|
|
|
} from '@heroicons/react/outline'
|
|
|
|
import { MngoMonoIcon } from '../components/icons'
|
|
|
|
import Link from 'next/link'
|
|
|
|
import { Table, Td, Th, TrBody, TrHead } from '../components/TableElements'
|
|
|
|
import AccountsModal from '../components/AccountsModal'
|
2022-02-10 17:50:40 -08:00
|
|
|
import { useViewport } from '../hooks/useViewport'
|
|
|
|
import { breakpoints } from '../components/TradePageGrid'
|
|
|
|
import { ExpandableRow } from '../components/TableElements'
|
|
|
|
import MobileTableHeader from '../components/mobile/MobileTableHeader'
|
2022-02-22 15:30:54 -08:00
|
|
|
import Input, { Label } from '../components/Input'
|
2022-02-10 18:29:07 -08:00
|
|
|
import InlineNotification from '../components/InlineNotification'
|
2022-02-14 11:21:06 -08:00
|
|
|
import useMangoAccount from '../hooks/useMangoAccount'
|
2022-03-18 12:13:16 -07:00
|
|
|
import { DateDisplay } from '../components/DateDisplay'
|
2022-02-14 09:15:28 -08:00
|
|
|
|
|
|
|
export async function getStaticProps({ locale }) {
|
|
|
|
return {
|
|
|
|
props: {
|
2022-02-19 11:36:29 -08:00
|
|
|
...(await serverSideTranslations(locale, ['common', 'referrals'])),
|
2022-02-14 09:15:28 -08:00
|
|
|
// Will be passed to the page component as props
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-14 12:48:40 -08:00
|
|
|
const ProgramDetails = () => {
|
2022-02-19 11:36:29 -08:00
|
|
|
const { t } = useTranslation('referrals')
|
2022-02-14 12:48:40 -08:00
|
|
|
return (
|
|
|
|
<>
|
2022-02-19 11:36:29 -08:00
|
|
|
<h2 className="mb-4">{t('referrals:program-details')}</h2>
|
2022-02-14 12:48:40 -08:00
|
|
|
<ul className="list-disc pl-3">
|
2022-02-19 11:36:29 -08:00
|
|
|
<li>{t('referrals:program-details-1')}</li>
|
|
|
|
<li>{t('referrals:program-details-2')}</li>
|
|
|
|
<li>{t('referrals:program-details-3')}</li>
|
|
|
|
<li>{t('referrals:program-details-4')}</li>
|
2022-02-14 12:48:40 -08:00
|
|
|
</ul>
|
|
|
|
</>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2022-02-14 09:15:46 -08:00
|
|
|
export default function Referral() {
|
2022-02-19 11:36:29 -08:00
|
|
|
const { t } = useTranslation(['common', 'referrals'])
|
2022-02-14 09:15:28 -08:00
|
|
|
const mangoGroup = useMangoStore(mangoGroupSelector)
|
2022-02-14 11:21:06 -08:00
|
|
|
const mangoCache = useMangoStore(mangoCacheSelector)
|
|
|
|
const { mangoAccount } = useMangoAccount()
|
2022-02-14 09:15:46 -08:00
|
|
|
const groupConfig = useMangoStore(mangoGroupConfigSelector)
|
2022-03-18 11:41:23 -07:00
|
|
|
const wallet = useMangoStore(walletSelector)
|
2022-02-10 15:48:14 -08:00
|
|
|
const connected = useMangoStore((s) => s.wallet.connected)
|
2022-03-15 15:48:26 -07:00
|
|
|
const actions = useMangoStore((s) => s.actions)
|
|
|
|
|
|
|
|
const referralHistory = useMangoStore((s) => s.referrals.history)
|
|
|
|
const referralTotalAmount = useMangoStore((s) => s.referrals.total)
|
2022-03-16 09:00:28 -07:00
|
|
|
const hasReferrals = referralHistory.length > 0
|
2022-02-14 09:15:28 -08:00
|
|
|
|
2022-02-14 09:17:11 -08:00
|
|
|
const [customRefLinkInput, setCustomRefLinkInput] = useState('')
|
2022-02-14 10:22:54 -08:00
|
|
|
const [existingCustomRefLinks, setexistingCustomRefLinks] = useState<
|
|
|
|
ReferrerIdRecord[]
|
|
|
|
>([])
|
2022-02-10 15:48:14 -08:00
|
|
|
const [hasCopied, setHasCopied] = useState(null)
|
|
|
|
const [showAccountsModal, setShowAccountsModal] = useState(false)
|
|
|
|
const [loading, setLoading] = useState(false)
|
2022-02-10 18:29:07 -08:00
|
|
|
const [inputError, setInputError] = useState('')
|
2022-02-10 17:50:40 -08:00
|
|
|
const { width } = useViewport()
|
|
|
|
const isMobile = width ? width < breakpoints.sm : false
|
2022-02-14 09:17:11 -08:00
|
|
|
|
|
|
|
const fetchCustomReferralLinks = useCallback(async () => {
|
2022-02-10 15:48:14 -08:00
|
|
|
setLoading(true)
|
2022-03-13 16:26:30 -07:00
|
|
|
const mangoClient = useMangoStore.getState().connection.client
|
|
|
|
const referrerIds = await mangoClient.getReferrerIdsForMangoAccount(
|
|
|
|
mangoAccount
|
|
|
|
)
|
2022-02-14 09:15:46 -08:00
|
|
|
|
2022-02-10 15:48:14 -08:00
|
|
|
setexistingCustomRefLinks(referrerIds)
|
|
|
|
setLoading(false)
|
2022-02-14 09:17:11 -08:00
|
|
|
}, [mangoAccount])
|
2022-02-14 09:15:46 -08:00
|
|
|
|
2022-02-14 09:17:11 -08:00
|
|
|
useEffect(() => {
|
|
|
|
if (mangoAccount) {
|
|
|
|
fetchCustomReferralLinks()
|
|
|
|
}
|
|
|
|
}, [mangoAccount])
|
2022-02-14 09:15:46 -08:00
|
|
|
|
2022-02-10 15:48:14 -08:00
|
|
|
useEffect(() => {
|
|
|
|
let timer
|
|
|
|
if (hasCopied) {
|
|
|
|
timer = setTimeout(() => setHasCopied(null), 1000)
|
|
|
|
}
|
|
|
|
return () => {
|
|
|
|
clearTimeout(timer)
|
|
|
|
}
|
|
|
|
}, [hasCopied])
|
|
|
|
|
2022-03-15 15:48:26 -07:00
|
|
|
useEffect(() => {
|
|
|
|
if (mangoAccount) {
|
|
|
|
actions.loadReferralData()
|
|
|
|
}
|
|
|
|
}, [mangoAccount])
|
|
|
|
|
2022-02-10 18:29:07 -08:00
|
|
|
const onChangeRefIdInput = (value) => {
|
2022-02-10 18:33:55 -08:00
|
|
|
const id = value.replace(/ /g, '')
|
|
|
|
setCustomRefLinkInput(id)
|
|
|
|
if (id.length > 32) {
|
2022-02-19 11:36:29 -08:00
|
|
|
setInputError(t('referrals:too-long-error'))
|
2022-02-10 18:29:07 -08:00
|
|
|
} else {
|
|
|
|
setInputError('')
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const validateRefIdInput = () => {
|
|
|
|
if (customRefLinkInput.length >= 33) {
|
2022-02-19 11:36:29 -08:00
|
|
|
setInputError(t('referrals:too-long-error'))
|
2022-02-10 18:29:07 -08:00
|
|
|
}
|
|
|
|
if (customRefLinkInput.length === 0) {
|
2022-02-19 13:14:58 -08:00
|
|
|
setInputError(t('referrals:enter-referral-id'))
|
2022-02-14 09:15:28 -08:00
|
|
|
}
|
2022-02-14 09:15:46 -08:00
|
|
|
}
|
|
|
|
|
2022-02-10 18:29:07 -08:00
|
|
|
const submitRefLink = async () => {
|
2022-02-22 09:52:35 -08:00
|
|
|
let encodedRefLink: string
|
|
|
|
try {
|
|
|
|
encodedRefLink = encodeURIComponent(customRefLinkInput)
|
|
|
|
} catch (e) {
|
|
|
|
notify({
|
|
|
|
type: 'error',
|
|
|
|
title: 'Invalid custom referral link',
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2022-02-10 18:29:07 -08:00
|
|
|
if (!inputError) {
|
|
|
|
try {
|
2022-03-13 16:26:30 -07:00
|
|
|
const mangoClient = useMangoStore.getState().connection.client
|
|
|
|
const txid = await mangoClient.registerReferrerId(
|
2022-02-10 18:29:07 -08:00
|
|
|
mangoGroup,
|
|
|
|
mangoAccount,
|
2022-03-18 11:41:23 -07:00
|
|
|
wallet,
|
2022-02-22 09:52:35 -08:00
|
|
|
encodedRefLink
|
2022-02-10 18:29:07 -08:00
|
|
|
)
|
|
|
|
notify({
|
|
|
|
txid,
|
2022-02-19 11:36:29 -08:00
|
|
|
title: t('referrals:link-created'),
|
2022-02-10 18:29:07 -08:00
|
|
|
})
|
2022-02-14 10:22:54 -08:00
|
|
|
fetchCustomReferralLinks()
|
2022-02-10 18:29:07 -08:00
|
|
|
} catch (e) {
|
|
|
|
notify({
|
|
|
|
type: 'error',
|
2022-02-19 11:36:29 -08:00
|
|
|
title: t('referrals:link-not-created'),
|
2022-02-10 18:29:07 -08:00
|
|
|
description: e.message,
|
|
|
|
txid: e.txid,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
} else return
|
|
|
|
}
|
|
|
|
|
2022-02-10 15:48:14 -08:00
|
|
|
const handleCopyLink = (link, index) => {
|
|
|
|
copyToClipboard(link)
|
|
|
|
setHasCopied(index)
|
|
|
|
}
|
|
|
|
|
2022-02-14 09:15:46 -08:00
|
|
|
const mngoIndex = getMarketIndexBySymbol(groupConfig, 'MNGO')
|
2022-02-14 11:21:06 -08:00
|
|
|
|
2022-02-14 09:15:46 -08:00
|
|
|
const hasRequiredMngo =
|
|
|
|
mangoGroup && mangoAccount
|
2022-02-14 11:36:04 -08:00
|
|
|
? mangoAccount
|
|
|
|
.getUiDeposit(
|
|
|
|
mangoCache.rootBankCache[mngoIndex],
|
|
|
|
mangoGroup,
|
|
|
|
mngoIndex
|
|
|
|
)
|
2022-02-14 14:23:57 -08:00
|
|
|
.toNumber() >= 10000
|
2022-02-14 09:15:46 -08:00
|
|
|
: false
|
2022-02-14 09:17:11 -08:00
|
|
|
const hasCustomRefLinks =
|
2022-02-10 15:48:14 -08:00
|
|
|
existingCustomRefLinks && existingCustomRefLinks.length > 0
|
2022-02-14 09:15:28 -08:00
|
|
|
|
|
|
|
return (
|
|
|
|
<div className={`bg-th-bkg-1 text-th-fgd-1 transition-all`}>
|
|
|
|
<TopBar />
|
|
|
|
<PageBodyContainer>
|
2022-02-10 15:48:14 -08:00
|
|
|
<div className="py-4 md:pb-4 md:pt-10">
|
2022-02-22 09:58:58 -08:00
|
|
|
<h1 className={`mb-1`}>{t('referrals:sow-seed')}</h1>
|
2022-03-09 12:53:11 -08:00
|
|
|
<div className="flex flex-col items-start sm:flex-row">
|
2022-02-22 15:34:54 -08:00
|
|
|
<p className="mb-0 mr-2">{t('referrals:earn-16')}</p>
|
2022-02-14 09:15:46 -08:00
|
|
|
</div>
|
2022-02-10 15:48:14 -08:00
|
|
|
</div>
|
2022-03-09 12:53:11 -08:00
|
|
|
<div className="grid grid-flow-row grid-cols-12 gap-x-6 gap-y-8 rounded-lg bg-th-bkg-2 p-4 sm:p-6">
|
2022-02-10 15:48:14 -08:00
|
|
|
{connected ? (
|
|
|
|
mangoAccount ? (
|
|
|
|
<>
|
2022-03-15 15:48:26 -07:00
|
|
|
{hasReferrals ? (
|
2022-02-10 15:48:14 -08:00
|
|
|
<div className="col-span-12">
|
2022-02-19 11:36:29 -08:00
|
|
|
<h2 className="mb-4">{t('referrals:your-referrals')}</h2>
|
2022-03-15 15:48:26 -07:00
|
|
|
<div className="grid-row-flow grid grid-cols-2 border-b border-th-bkg-4 sm:gap-6 sm:border-b-0">
|
|
|
|
<div className="col-span-2 border-t border-th-bkg-4 p-3 sm:col-span-1 sm:border-b sm:p-4">
|
|
|
|
<div className="pb-0.5 text-xs text-th-fgd-3 sm:text-sm">
|
2022-02-19 11:36:29 -08:00
|
|
|
{t('referrals:total-earnings')}
|
2022-02-10 15:48:14 -08:00
|
|
|
</div>
|
2022-03-15 15:48:26 -07:00
|
|
|
<div className="text-xl font-bold text-th-fgd-1 sm:text-2xl">
|
|
|
|
{formatUsdValue(referralTotalAmount)}
|
2022-02-10 15:48:14 -08:00
|
|
|
</div>
|
|
|
|
</div>
|
2022-03-15 15:48:26 -07:00
|
|
|
<div className="col-span-2 border-t border-th-bkg-4 p-3 sm:col-span-1 sm:border-b sm:p-4">
|
|
|
|
<div className="pb-0.5 text-xs text-th-fgd-3 sm:text-sm">
|
2022-02-19 11:36:29 -08:00
|
|
|
{t('referrals:total-referrals')}
|
2022-02-10 15:48:14 -08:00
|
|
|
</div>
|
2022-03-15 15:48:26 -07:00
|
|
|
<div className="text-xl font-bold text-th-fgd-1 sm:text-2xl">
|
|
|
|
{referralHistory.length}
|
2022-02-10 15:48:14 -08:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2022-02-14 09:15:46 -08:00
|
|
|
</div>
|
2022-03-15 15:48:26 -07:00
|
|
|
) : null}
|
2022-02-10 15:48:14 -08:00
|
|
|
<div className="col-span-12">
|
2022-03-09 12:53:11 -08:00
|
|
|
<div className="flex w-full flex-col space-y-4 xl:flex-row xl:space-x-6 xl:space-y-0">
|
|
|
|
<div className="min-w-[25%] flex-1 rounded-md bg-th-bkg-3 p-6">
|
2022-02-14 12:48:40 -08:00
|
|
|
<ProgramDetails />
|
2022-02-14 11:36:04 -08:00
|
|
|
</div>
|
2022-03-09 12:53:11 -08:00
|
|
|
<div className="flex w-full flex-col">
|
2022-02-10 15:48:14 -08:00
|
|
|
{hasRequiredMngo ? (
|
2022-03-09 12:53:11 -08:00
|
|
|
<div className="flex-1 rounded-md bg-th-bkg-3 p-6">
|
2022-02-19 11:36:29 -08:00
|
|
|
<h2 className="mb-4">{t('referrals:your-links')}</h2>
|
2022-02-10 15:48:14 -08:00
|
|
|
{!loading ? (
|
|
|
|
!hasCustomRefLinks ? (
|
|
|
|
<Table>
|
|
|
|
<thead>
|
|
|
|
<TrHead>
|
2022-02-19 11:36:29 -08:00
|
|
|
<Th>{t('referrlals:link')}</Th>
|
|
|
|
<Th>{t('referrlals:copy-link')}</Th>
|
2022-02-10 15:48:14 -08:00
|
|
|
</TrHead>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
<TrBody>
|
|
|
|
<Td>
|
2022-02-10 17:50:40 -08:00
|
|
|
<div className="flex items-center">
|
|
|
|
{!isMobile ? (
|
2022-03-09 12:53:11 -08:00
|
|
|
<LinkIcon className="mr-1.5 h-4 w-4" />
|
2022-02-10 17:50:40 -08:00
|
|
|
) : null}
|
2022-03-09 12:53:11 -08:00
|
|
|
<p className="mb-0 max-w-md text-th-fgd-1">
|
2022-02-10 17:50:40 -08:00
|
|
|
{isMobile
|
|
|
|
? abbreviateAddress(
|
|
|
|
mangoAccount.publicKey
|
|
|
|
)
|
2022-02-14 12:48:40 -08:00
|
|
|
: `https://trade.mango.markets?ref=${mangoAccount.publicKey.toString()}`}
|
2022-02-10 17:50:40 -08:00
|
|
|
</p>
|
|
|
|
</div>
|
2022-02-10 15:48:14 -08:00
|
|
|
</Td>
|
|
|
|
<Td className="flex items-center justify-end">
|
|
|
|
<IconButton
|
|
|
|
className={`flex-shrink-0 ${
|
|
|
|
hasCopied === 1 && 'bg-th-green'
|
|
|
|
}`}
|
|
|
|
disabled={hasCopied}
|
|
|
|
onClick={() =>
|
|
|
|
handleCopyLink(
|
|
|
|
`https://trade.mango.markets?ref=${mangoAccount.publicKey.toString()}`,
|
|
|
|
1
|
|
|
|
)
|
|
|
|
}
|
|
|
|
>
|
|
|
|
{hasCopied === 1 ? (
|
|
|
|
<CheckIcon className="h-5 w-5" />
|
|
|
|
) : (
|
|
|
|
<DuplicateIcon className="h-4 w-4" />
|
|
|
|
)}
|
|
|
|
</IconButton>
|
|
|
|
</Td>
|
|
|
|
</TrBody>
|
|
|
|
</tbody>
|
|
|
|
</Table>
|
|
|
|
) : (
|
|
|
|
<Table>
|
|
|
|
<thead>
|
|
|
|
<TrHead>
|
2022-02-19 11:36:29 -08:00
|
|
|
<Th>{t('referrals:link')}</Th>
|
2022-02-10 15:48:14 -08:00
|
|
|
<Th>
|
|
|
|
<div className="flex justify-end">
|
2022-02-19 11:36:29 -08:00
|
|
|
{t('referrals:copy-link')}
|
2022-02-10 15:48:14 -08:00
|
|
|
</div>
|
|
|
|
</Th>
|
|
|
|
</TrHead>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
{existingCustomRefLinks.map(
|
|
|
|
(customRefs, index) => (
|
|
|
|
<TrBody key={customRefs.referrerId}>
|
|
|
|
<Td>
|
|
|
|
<div className="flex items-center">
|
2022-02-10 17:50:40 -08:00
|
|
|
{!isMobile ? (
|
2022-03-09 12:53:11 -08:00
|
|
|
<LinkIcon className="mr-1.5 h-4 w-4" />
|
2022-02-10 17:50:40 -08:00
|
|
|
) : null}
|
2022-02-10 15:48:14 -08:00
|
|
|
<p className="mb-0 text-th-fgd-1">
|
2022-02-10 17:50:40 -08:00
|
|
|
{isMobile
|
|
|
|
? customRefs.referrerId
|
|
|
|
: `https://trade.mango.markets?ref=${customRefs.referrerId}`}
|
2022-02-10 15:48:14 -08:00
|
|
|
</p>
|
|
|
|
</div>
|
|
|
|
</Td>
|
|
|
|
<Td className="flex items-center justify-end">
|
|
|
|
<IconButton
|
|
|
|
className={`flex-shrink-0 ${
|
|
|
|
hasCopied === index + 1 &&
|
|
|
|
'bg-th-green'
|
|
|
|
}`}
|
|
|
|
disabled={hasCopied}
|
|
|
|
onClick={() =>
|
|
|
|
handleCopyLink(
|
|
|
|
`https://trade.mango.markets?ref=${customRefs.referrerId}`,
|
|
|
|
index + 1
|
|
|
|
)
|
|
|
|
}
|
|
|
|
>
|
|
|
|
{hasCopied === index + 1 ? (
|
|
|
|
<CheckIcon className="h-5 w-5" />
|
|
|
|
) : (
|
|
|
|
<DuplicateIcon className="h-4 w-4" />
|
|
|
|
)}
|
|
|
|
</IconButton>
|
|
|
|
</Td>
|
|
|
|
</TrBody>
|
|
|
|
)
|
|
|
|
)}
|
|
|
|
</tbody>
|
|
|
|
</Table>
|
|
|
|
)
|
|
|
|
) : (
|
|
|
|
<div className="space-y-2">
|
2022-03-09 12:53:11 -08:00
|
|
|
<div className="h-16 animate-pulse bg-th-bkg-4" />
|
|
|
|
<div className="h-16 animate-pulse bg-th-bkg-4" />
|
|
|
|
<div className="h-16 animate-pulse bg-th-bkg-4" />
|
2022-02-10 15:48:14 -08:00
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
) : (
|
2022-03-09 12:53:11 -08:00
|
|
|
<div className="flex flex-1 flex-col items-center justify-center rounded-md bg-th-bkg-3 px-4 py-8 text-center">
|
|
|
|
<MngoMonoIcon className="mb-2 h-6 w-6 text-th-fgd-2" />
|
2022-02-19 11:36:29 -08:00
|
|
|
<p className="mb-0">{t('referrals:10k-mngo')}</p>
|
2022-02-10 15:48:14 -08:00
|
|
|
|
|
|
|
<Link href={'/?name=MNGO/USDC'} shallow={true}>
|
2022-03-09 12:53:11 -08:00
|
|
|
<a className="mt-4 rounded-full bg-th-bkg-button px-6 py-2 font-bold text-th-fgd-1 hover:text-th-fgd-1 hover:brightness-[1.15] focus:outline-none">
|
2022-02-19 11:36:29 -08:00
|
|
|
{t('referrals:buy-mngo')}
|
2022-02-10 15:48:14 -08:00
|
|
|
</a>
|
|
|
|
</Link>
|
|
|
|
</div>
|
|
|
|
)}
|
2022-02-14 09:17:11 -08:00
|
|
|
</div>
|
2022-02-14 10:22:54 -08:00
|
|
|
{hasRequiredMngo ? (
|
2022-03-09 12:53:11 -08:00
|
|
|
<div className="w-full min-w-[25%] rounded-md bg-th-bkg-3 p-6 xl:w-1/3">
|
2022-02-19 11:36:29 -08:00
|
|
|
<h2 className="mb-1">{t('referrals:custom-links')}</h2>
|
2022-02-10 17:50:40 -08:00
|
|
|
<p className="mb-4">
|
2022-02-19 11:36:29 -08:00
|
|
|
{t('referrals:custom-links-limit')}
|
2022-02-10 17:50:40 -08:00
|
|
|
</p>
|
|
|
|
<div className="pb-6">
|
2022-02-22 15:34:54 -08:00
|
|
|
<Label>{t('referrals:referral-id')}</Label>
|
2022-02-10 18:29:07 -08:00
|
|
|
<Input
|
2022-03-18 12:13:16 -07:00
|
|
|
error={inputError}
|
2022-02-10 17:50:40 -08:00
|
|
|
type="text"
|
|
|
|
placeholder="ElonMusk"
|
2022-02-10 18:29:07 -08:00
|
|
|
onBlur={validateRefIdInput}
|
|
|
|
onChange={(e) => onChangeRefIdInput(e.target.value)}
|
2022-02-10 17:50:40 -08:00
|
|
|
value={customRefLinkInput}
|
2022-02-14 10:22:54 -08:00
|
|
|
disabled={existingCustomRefLinks.length === 5}
|
2022-02-10 17:50:40 -08:00
|
|
|
/>
|
2022-02-10 18:29:07 -08:00
|
|
|
{inputError ? (
|
|
|
|
<div className="pt-2">
|
|
|
|
<InlineNotification
|
|
|
|
type="error"
|
|
|
|
desc={inputError}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
) : null}
|
2022-02-10 17:50:40 -08:00
|
|
|
</div>
|
2022-02-22 15:30:54 -08:00
|
|
|
<Button
|
2022-02-10 17:50:40 -08:00
|
|
|
onClick={submitRefLink}
|
2022-02-14 10:22:54 -08:00
|
|
|
disabled={existingCustomRefLinks.length === 5}
|
2022-02-10 17:50:40 -08:00
|
|
|
>
|
2022-02-22 15:30:54 -08:00
|
|
|
<div className="flex items-center">
|
2022-03-09 12:53:11 -08:00
|
|
|
<LinkIcon className="mr-1.5 h-4 w-4" />
|
2022-02-22 15:34:54 -08:00
|
|
|
{t('referrals:generate-link')}
|
2022-02-22 15:30:54 -08:00
|
|
|
</div>
|
|
|
|
</Button>
|
2022-02-10 17:50:40 -08:00
|
|
|
</div>
|
|
|
|
) : null}
|
2022-02-10 15:48:14 -08:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
{referralHistory.length > 0 ? (
|
|
|
|
<div className="col-span-12">
|
2022-02-19 11:36:29 -08:00
|
|
|
<h2 className="mb-4">{t('referrals:earnings-history')}</h2>
|
2022-02-10 17:50:40 -08:00
|
|
|
{!isMobile ? (
|
|
|
|
<Table>
|
|
|
|
<thead>
|
|
|
|
<TrHead>
|
|
|
|
<Th>{t('date')}</Th>
|
2022-02-19 11:36:29 -08:00
|
|
|
<Th>{t('referrals:referee')}</Th>
|
2022-02-10 17:50:40 -08:00
|
|
|
<Th>
|
2022-02-19 11:36:29 -08:00
|
|
|
<div className="flex justify-end">
|
|
|
|
{t('referrals:fee-earned')}
|
|
|
|
</div>
|
2022-02-10 17:50:40 -08:00
|
|
|
</Th>
|
|
|
|
</TrHead>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
2022-03-17 09:36:09 -07:00
|
|
|
{referralHistory.map((ref) => {
|
|
|
|
const pk = ref.referrer_mango_account
|
|
|
|
const acct = pk.slice(0, 5) + '…' + pk.slice(-5)
|
|
|
|
|
|
|
|
return (
|
|
|
|
<TrBody key={ref.signature}>
|
|
|
|
<Td>
|
2022-03-18 11:41:19 -07:00
|
|
|
<DateDisplay date={ref.block_datetime} />
|
2022-03-17 09:36:09 -07:00
|
|
|
</Td>
|
|
|
|
<Td>
|
|
|
|
<Link
|
|
|
|
href={`/account?pubkey=${ref.referree_mango_account}`}
|
|
|
|
shallow={true}
|
|
|
|
>
|
|
|
|
<a className="text-th-fgd-2 underline hover:text-th-fgd-3 hover:no-underline">
|
|
|
|
{acct}
|
|
|
|
</a>
|
|
|
|
</Link>
|
|
|
|
</Td>
|
|
|
|
<Td className="flex items-center justify-end">
|
2022-03-18 11:41:19 -07:00
|
|
|
{usdFormatter(ref.referral_fee_accrual, 4)}
|
2022-03-17 09:36:09 -07:00
|
|
|
</Td>
|
|
|
|
</TrBody>
|
|
|
|
)
|
|
|
|
})}
|
2022-02-10 17:50:40 -08:00
|
|
|
</tbody>
|
|
|
|
</Table>
|
|
|
|
) : (
|
|
|
|
<>
|
|
|
|
<MobileTableHeader
|
|
|
|
colOneHeader={t('date')}
|
2022-03-18 11:41:19 -07:00
|
|
|
colTwoHeader={t('referrals:fee-earned')}
|
2022-02-10 17:50:40 -08:00
|
|
|
/>
|
2022-02-10 15:48:14 -08:00
|
|
|
{referralHistory.map((ref, index) => (
|
2022-02-10 17:50:40 -08:00
|
|
|
<ExpandableRow
|
|
|
|
buttonTemplate={
|
2022-03-09 12:53:11 -08:00
|
|
|
<div className="flex w-full items-center justify-between text-th-fgd-1">
|
2022-02-10 17:50:40 -08:00
|
|
|
<div>
|
2022-03-18 11:41:19 -07:00
|
|
|
<DateDisplay date={ref.block_datetime} />
|
|
|
|
</div>
|
|
|
|
<div className="text-right">
|
|
|
|
{usdFormatter(ref.referral_fee_accrual, 4)}
|
2022-02-10 17:50:40 -08:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
}
|
2022-03-18 12:13:16 -07:00
|
|
|
key={`${ref.referral_fee_accrual + index}`}
|
2022-02-10 17:50:40 -08:00
|
|
|
panelTemplate={
|
|
|
|
<>
|
2022-03-18 11:41:19 -07:00
|
|
|
<div className="grid grid-flow-row grid-cols-2 gap-4">
|
2022-02-10 17:50:40 -08:00
|
|
|
<div className="text-left">
|
2022-03-09 12:53:11 -08:00
|
|
|
<div className="pb-0.5 text-xs text-th-fgd-3">
|
2022-02-19 11:36:29 -08:00
|
|
|
{t('referrals:referee')}
|
2022-02-10 17:50:40 -08:00
|
|
|
</div>
|
|
|
|
<Link
|
2022-03-18 11:41:19 -07:00
|
|
|
href={`/account?pubkey=${ref.referree_mango_account}`}
|
2022-02-10 17:50:40 -08:00
|
|
|
shallow={true}
|
|
|
|
>
|
2022-03-09 12:53:11 -08:00
|
|
|
<a className="text-th-fgd-2 underline hover:text-th-fgd-3 hover:no-underline">
|
2022-02-10 17:50:40 -08:00
|
|
|
{abbreviateAddress(
|
|
|
|
mangoAccount.publicKey
|
|
|
|
)}
|
|
|
|
</a>
|
|
|
|
</Link>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</>
|
|
|
|
}
|
|
|
|
/>
|
2022-02-10 15:48:14 -08:00
|
|
|
))}
|
2022-02-10 17:50:40 -08:00
|
|
|
</>
|
|
|
|
)}
|
2022-02-10 15:48:14 -08:00
|
|
|
</div>
|
|
|
|
) : null}
|
|
|
|
</>
|
|
|
|
) : (
|
2022-02-14 12:48:40 -08:00
|
|
|
<>
|
2022-03-09 12:53:11 -08:00
|
|
|
<div className="col-span-12 rounded-md bg-th-bkg-3 p-6 lg:col-span-4">
|
2022-02-14 12:48:40 -08:00
|
|
|
<ProgramDetails />
|
|
|
|
</div>
|
2022-03-09 12:53:11 -08:00
|
|
|
<div className="col-span-12 flex items-center justify-center rounded-md bg-th-bkg-3 p-6 lg:col-span-8">
|
2022-02-14 12:48:40 -08:00
|
|
|
<EmptyState
|
|
|
|
buttonText={t('create-account')}
|
|
|
|
icon={<CurrencyDollarIcon />}
|
|
|
|
onClickButton={() => setShowAccountsModal(true)}
|
|
|
|
title={t('no-account-found')}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
</>
|
|
|
|
)
|
|
|
|
) : (
|
|
|
|
<>
|
2022-03-09 12:53:11 -08:00
|
|
|
<div className="col-span-12 rounded-md bg-th-bkg-3 p-6 lg:col-span-4">
|
2022-02-14 12:48:40 -08:00
|
|
|
<ProgramDetails />
|
|
|
|
</div>
|
2022-03-09 12:53:11 -08:00
|
|
|
<div className="col-span-12 flex items-center justify-center rounded-md bg-th-bkg-3 p-6 lg:col-span-8">
|
2022-02-10 15:48:14 -08:00
|
|
|
<EmptyState
|
2022-02-14 12:48:40 -08:00
|
|
|
buttonText={t('connect')}
|
|
|
|
icon={<LinkIcon />}
|
2022-03-18 11:41:23 -07:00
|
|
|
onClickButton={() => wallet.connect()}
|
2022-02-14 12:48:40 -08:00
|
|
|
title={t('connect-wallet')}
|
2022-02-10 15:48:14 -08:00
|
|
|
/>
|
|
|
|
</div>
|
2022-02-14 12:48:40 -08:00
|
|
|
</>
|
2022-02-10 15:48:14 -08:00
|
|
|
)}
|
2022-02-14 09:15:46 -08:00
|
|
|
</div>
|
2022-02-14 09:15:28 -08:00
|
|
|
</PageBodyContainer>
|
2022-02-10 15:48:14 -08:00
|
|
|
{showAccountsModal ? (
|
|
|
|
<AccountsModal
|
|
|
|
onClose={() => setShowAccountsModal(false)}
|
|
|
|
isOpen={showAccountsModal}
|
|
|
|
/>
|
|
|
|
) : null}
|
2022-02-14 09:15:28 -08:00
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|