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

Commit

Permalink
adds extrapolated comps to index
Browse files Browse the repository at this point in the history
  • Loading branch information
W3stside committed Jan 10, 2022
1 parent c40d368 commit ebc4872
Showing 1 changed file with 14 additions and 137 deletions.
151 changes: 14 additions & 137 deletions src/custom/pages/Claim/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -18,16 +18,9 @@ import {
ConfirmOrLoadingWrapper,
ConfirmedIcon,
AttemptFooter,
ClaimSummary,
ClaimTotal,
IntroDescription,
ClaimTable,
ClaimAccount,
InputField,
CheckAddress,
ClaimBreakdown,
FooterNavButtons,
TopNav,
InvestFlow,
InvestContent,
InvestTokenGroup,
Expand All @@ -39,10 +32,6 @@ import {
StepIndicator,
Steps,
TokenLogo,
ClaimSummaryTitle,
InputErrorText,
InputFieldTitle,
ClaimAccountButtons,
} from 'pages/Claim/styled'
import EligibleBanner from './EligibleBanner'
import {
Expand All @@ -58,16 +47,14 @@ import {
import { useWalletModalToggle } from 'state/application/hooks'
import CowProtocolLogo from 'components/CowProtocolLogo'
import Confetti from 'components/Confetti'
import { shortenAddress } from 'utils'
import { isAddress } from 'web3-utils'
import useENS from 'hooks/useENS'
import { TYPE } from 'theme'
import { formatSmart } from 'utils/format'
import { useClaimReducer, ClaimContext } from './state'

// should be updated
const DUMMY_IDENTICON =
''
import ClaimNav from './ClaimNav'
import ClaimSummary from './ClaimSummary'
import ClaimAddress from './ClaimAddress'
import CanUserClaimMessage from './CanUserClaimMessage'

export default function Claim() {
const { account, chainId } = useActiveWeb3React()
Expand All @@ -80,7 +67,6 @@ export default function Claim() {
inputAddress,
// account
activeClaimAccount,
activeClaimAccountENS,
// check address
isSearchUsed,
// claiming
Expand Down Expand Up @@ -116,15 +102,9 @@ export default function Claim() {
setSelectedAll,
} = dispatchers

const { loading, address: resolvedAddress, name: resolvedENS } = useENS(inputAddress)
const { address: resolvedAddress, name: resolvedENS } = useENS(inputAddress)
const isInputAddressValid = useMemo(() => isAddress(resolvedAddress || ''), [resolvedAddress])

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

// toggle wallet when disconnected
const toggleWalletModal = useWalletModalToggle()

Expand Down Expand Up @@ -170,12 +150,6 @@ export default function Claim() {
setSelectedAll(checked)
}

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

// handle change account
const handleChangeAccount = () => {
setActiveClaimAccount('')
Expand Down Expand Up @@ -263,114 +237,17 @@ export default function Claim() {
<PageWrapper>
{/* If claim is confirmed > trigger confetti effect */}
<Confetti start={claimConfirmed} />
{/* START -- Top nav buttons */}
{!!activeClaimAccount && (
<TopNav>
<ClaimAccount>
<div>
<img src={DUMMY_IDENTICON} alt={activeClaimAccount} />
<p>{activeClaimAccountENS ? activeClaimAccountENS : shortenAddress(activeClaimAccount)}</p>
</div>

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

<ButtonSecondary disabled={claimAttempting} onClick={handleChangeAccount}>
Change account
</ButtonSecondary>
</ClaimAccountButtons>
</ClaimAccount>
</TopNav>
)}
{/* END -- Top nav buttons */}

{/* START - Show general title OR total to claim (user has airdrop or airdrop+investment) --------------------------- */}
{/* Top nav buttons */}
<ClaimNav account={account} handleChangeAccount={handleChangeAccount} />
{/* Show general title OR total to claim (user has airdrop or airdrop+investment) --------------------------- */}
<EligibleBanner hasClaims={hasClaims} />

{!claimAttempting && !claimConfirmed && !claimSubmitted && !isInvestFlowActive && (
<ClaimSummary>
<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>
)}
</ClaimSummary>
)}
{/* END - Show total to claim (user has airdrop or airdrop+investment) --------------------------- */}

{/* START - Get address/ENS (user not connected yet or opted for checking 'another' account) */}
{!activeClaimAccount && !claimConfirmed && (
<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>
)}
{/* END - Get address/ENS (user not connected yet or opted for checking 'another' account) */}

{/* START -- IS Airdrop only (simple) ----------------------------------------------------- */}
{!!activeClaimAccount && !!hasClaims && !!isAirdropOnly && !claimAttempting && !claimConfirmed && (
<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>
)}
{/* END -- IS Airdrop only (simple) ---------------------------------------- */}

{/* START -- NO CLAIMS ----------------------------------------------------- */}
{!!activeClaimAccount && !hasClaims && !claimAttempting && !claimConfirmed && (
<IntroDescription>
<Trans>
Unfortunately this account is not eligible for any vCOW claims.{' '}
<ButtonSecondary onClick={() => setActiveClaimAccount('')}>Try another account</ButtonSecondary> or
<ExternalLink href="https://cow.fi/">read more about vCOW</ExternalLink>
</Trans>
</IntroDescription>
)}
{/* END ---- NO CLAIMS ----------------------------------------------------- */}
{/* Show total to claim (user has airdrop or airdrop+investment) */}
<ClaimSummary hasClaims={hasClaims} unclaimedAmount={unclaimedAmount} />
{/* Get address/ENS (user not connected yet or opted for checking 'another' account) */}
<ClaimAddress account={account} toggleWalletModal={toggleWalletModal} />
{/* Is Airdrop only (simple) - does user have claims? Show messages dependent on claim state */}
<CanUserClaimMessage hasClaims={hasClaims} isAirdropOnly={isAirdropOnly} />

{/* START - Try claiming or inform succesfull claim ---------------------- */}
{activeClaimAccount && (claimAttempting || claimConfirmed) && (
Expand Down

0 comments on commit ebc4872

Please sign in to comment.