Skip to content
This repository has been archived by the owner on Jun 24, 2022. It is now read-only.

Commit

Permalink
[Claim refactor index] - Part 1 - Extrapolate 5 small components (sum…
Browse files Browse the repository at this point in the history
…mary, nav, claim messages) (#2072)

* move dummy ident

* common types file

* Component extrapolate: ClaimNav

* Component extrapolate: ClaimSummary

* Component extrapolate: ClaimAddress

* Component extrapolate: CanUserClaimMessage

* adds extrapolated components to index
  • Loading branch information
W3stside authored Jan 11, 2022
1 parent 48d1b7a commit f92674b
Show file tree
Hide file tree
Showing 6 changed files with 223 additions and 137 deletions.
49 changes: 49 additions & 0 deletions src/custom/pages/Claim/CanUserClaimMessage.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
import { Trans } from '@lingui/macro'
import { ButtonSecondary } from 'components/Button'
import { ExternalLink } from 'theme'
import useClaimState from './state'
import { IntroDescription } from './styled'
import { ClaimCommonTypes } from './types'

type ClaimIntroductionProps = Pick<ClaimCommonTypes, 'hasClaims'> & {
isAirdropOnly: boolean
}

export default function CanUserClaimMessage({ hasClaims, isAirdropOnly }: ClaimIntroductionProps) {
const {
state: { activeClaimAccount, claimAttempting, claimConfirmed },
dispatchers,
} = useClaimState()

const canClaim = !claimAttempting && !claimConfirmed && hasClaims && isAirdropOnly

// only show when active claim account
if (!activeClaimAccount) return null

if (canClaim) {
return (
<IntroDescription>
<p>
<Trans>
Thank you for being a supporter of CowSwap and the CoW protocol. As an important member of the CowSwap
Community you may claim vCOW to be used for voting and governance. You can claim your tokens until{' '}
<i>[XX-XX-XXXX - XX:XX GMT]</i>
<ExternalLink href="https://cow.fi/">Read more about vCOW</ExternalLink>
</Trans>
</p>
</IntroDescription>
)
} else {
return (
<IntroDescription>
<Trans>
Unfortunately this account is not eligible for any vCOW claims.{' '}
<ButtonSecondary onClick={() => dispatchers?.setActiveClaimAccount('')} padding="0">
Try another account
</ButtonSecondary>{' '}
or <ExternalLink href="https://cow.fi/">read more about vCOW</ExternalLink>
</Trans>
</IntroDescription>
)
}
}
67 changes: 67 additions & 0 deletions src/custom/pages/Claim/ClaimAddress.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
import { useMemo } from 'react'
import { Trans } from '@lingui/macro'
import { ButtonSecondary } from 'components/Button'
import Circle from 'assets/images/blue-loader.svg'
import { CustomLightSpinner, TYPE } from 'theme'
import { CheckAddress, InputField, InputFieldTitle, InputErrorText } from './styled'
import useClaimState from './state'
import { ClaimCommonTypes } from './types'
import useENS from 'hooks/useENS'

type ClaimAddressProps = Pick<ClaimCommonTypes, 'account'> & {
toggleWalletModal: () => void
}

export default function ClaimAddress({ account, toggleWalletModal }: ClaimAddressProps) {
const {
state: { activeClaimAccount, claimConfirmed, inputAddress },
dispatchers,
} = useClaimState()

const { loading, address: resolvedAddress } = useENS(inputAddress)

// Show input error
const showInputError = useMemo(
() => Boolean(inputAddress.length > 0 && !loading && !resolvedAddress),
[resolvedAddress, inputAddress, loading]
)

const handleInputChange = (event: React.ChangeEvent<HTMLInputElement>) => {
const input = event.target.value
const withoutSpaces = input.replace(/\s+/g, '')

dispatchers?.setInputAddress(withoutSpaces)
}

if (activeClaimAccount || claimConfirmed) return null

return (
<CheckAddress>
<p>
Enter an address to check for any eligible vCOW claims. <br />
<i>Note: It is possible to claim for an account, using any wallet/account.</i>
{!account && (
<ButtonSecondary onClick={toggleWalletModal}>
<Trans>or connect a wallet</Trans>
</ButtonSecondary>
)}
</p>

<InputField>
<InputFieldTitle>
<b>Input address</b>
{loading && <CustomLightSpinner src={Circle} alt="loader" size={'10px'} />}
</InputFieldTitle>
<input placeholder="Address or ENS name" value={inputAddress} onChange={handleInputChange} />
</InputField>

{showInputError && (
<InputErrorText>
<TYPE.error error={true}>
<Trans>Enter valid token address or ENS</Trans>
</TYPE.error>
</InputErrorText>
)}
</CheckAddress>
)
}
43 changes: 43 additions & 0 deletions src/custom/pages/Claim/ClaimNav.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
import { ButtonSecondary } from 'components/Button'
import { shortenAddress } from 'utils'
import useClaimState from './state'
import { TopNav, ClaimAccount, ClaimAccountButtons } from './styled'
import { ClaimCommonTypes } from './types'

// should be updated
const DUMMY_IDENTICON =
''

type ClaimNavProps = Pick<ClaimCommonTypes, 'account' | 'handleChangeAccount'>

export default function ClaimNav({ account, handleChangeAccount }: ClaimNavProps) {
const {
state: { activeClaimAccount, activeClaimAccountENS, claimAttempting },
dispatchers,
} = useClaimState()

if (!activeClaimAccount) return null

return (
<TopNav>
<ClaimAccount>
<div>
<img src={DUMMY_IDENTICON} alt={activeClaimAccount} />
<p>{activeClaimAccountENS ? activeClaimAccountENS : shortenAddress(activeClaimAccount)}</p>
</div>

<ClaimAccountButtons>
{!!account && account !== activeClaimAccount && (
<ButtonSecondary disabled={claimAttempting} onClick={() => dispatchers?.setActiveClaimAccount(account)}>
Your claims
</ButtonSecondary>
)}

<ButtonSecondary disabled={claimAttempting} onClick={handleChangeAccount}>
Change account
</ButtonSecondary>
</ClaimAccountButtons>
</ClaimAccount>
</TopNav>
)
}
41 changes: 41 additions & 0 deletions src/custom/pages/Claim/ClaimSummary.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
import { Trans } from '@lingui/macro'
import CowProtocolLogo from 'components/CowProtocolLogo'
import { formatSmart } from 'utils/format'
import useClaimState from './state'
import { ClaimSummary as ClaimSummaryWrapper, ClaimSummaryTitle, ClaimTotal } from './styled'
import { ClaimCommonTypes } from './types'

type ClaimSummaryProps = Pick<ClaimCommonTypes, 'hasClaims'> & {
unclaimedAmount: ClaimCommonTypes['tokenCurrencyAmount'] | undefined
}

export default function ClaimSummary({ hasClaims, unclaimedAmount }: ClaimSummaryProps) {
const {
state: { activeClaimAccount, claimAttempting, claimConfirmed, claimSubmitted, isInvestFlowActive },
} = useClaimState()

const hasClaimSummary = !claimAttempting && !claimConfirmed && !claimSubmitted && !isInvestFlowActive

if (!hasClaimSummary) return null

return (
<ClaimSummaryWrapper>
<CowProtocolLogo size={100} />
{!activeClaimAccount && !hasClaims && (
<ClaimSummaryTitle>
<Trans>
Claim <b>vCOW</b> token
</Trans>
</ClaimSummaryTitle>
)}
{activeClaimAccount && (
<div>
<ClaimTotal>
<b>Total available to claim</b>
<p>{formatSmart(unclaimedAmount)} vCOW</p>
</ClaimTotal>
</div>
)}
</ClaimSummaryWrapper>
)
}
Loading

0 comments on commit f92674b

Please sign in to comment.