Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: use Swap Component on TDP #6332

Merged
merged 39 commits into from
May 2, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
39 commits
Select commit Hold shift + click to select a range
9698bd4
test: swap flow cypress tests
just-toby Apr 10, 2023
16dd116
fix: use default parameter
just-toby Apr 10, 2023
129b28a
feat: use Swap Component on TDP
just-toby Apr 11, 2023
7236cba
feat: auto nav for TDP tokens
just-toby Apr 11, 2023
29643f9
chore: merge
just-toby Apr 20, 2023
8a80368
chore: merge
just-toby Apr 20, 2023
0b68684
chore: merge
just-toby Apr 20, 2023
cab2b59
chore: merge
just-toby Apr 20, 2023
f5ab2b6
chore: merge
just-toby Apr 24, 2023
82ae506
chore: merge
just-toby Apr 24, 2023
275656e
fix: remove extra inputCurrency URL parsing logic
just-toby Apr 24, 2023
36a3a88
fix: undo last change
just-toby Apr 24, 2023
cc4fce9
fix: pass expected chain id to swap component
just-toby Apr 24, 2023
3c57ef8
fix: search for default tokens on unconnected networks if needed
just-toby Apr 24, 2023
8223dcd
test: e2e test for l2 token
just-toby Apr 24, 2023
15cac1f
fix: delete irrelevant tests
just-toby Apr 24, 2023
be8b155
fix: address comments
just-toby Apr 24, 2023
7408bc4
fix: lint error
just-toby Apr 24, 2023
18d9d83
test: update TDP e2e tests
just-toby Apr 24, 2023
9f3b158
fix: use pageChainId for filter
just-toby Apr 25, 2023
626234b
fix: rename chainId
just-toby Apr 25, 2023
8ddb100
fix: typecheck
just-toby Apr 25, 2023
aa51523
fix: chainId bug
just-toby Apr 25, 2023
8f2977a
chore: merge
just-toby Apr 25, 2023
ba7b6d3
fix: chainId required fixes
just-toby Apr 25, 2023
e49ee48
fix: bad merge in e2e test
just-toby Apr 26, 2023
21ee43e
chore: merge
just-toby Apr 26, 2023
e4c4e90
fix: remove unused test util
just-toby Apr 26, 2023
c3af201
fix: remove unnecessary variable
just-toby Apr 26, 2023
e7e2c38
fix: token defaults
just-toby Apr 26, 2023
9fb00db
chore: merge
just-toby Apr 26, 2023
a53d0a7
fix: address comments
just-toby Apr 27, 2023
3041007
fix: address comments and fix tests
just-toby Apr 27, 2023
74746f8
fix: e2e test formatting, remove Maybe<>
just-toby Apr 27, 2023
f09a181
fix: remove unused variable
just-toby Apr 27, 2023
022d132
chore: merge
just-toby Apr 28, 2023
05bc88e
fix: use feature flag for swap component on TDP
just-toby May 2, 2023
6f347a1
fix: back button
just-toby May 2, 2023
d131136
fix: merge
just-toby May 2, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
fix: address comments
  • Loading branch information
just-toby committed Apr 24, 2023
commit be8b15515f19d69045764bd68e443c09d13cbea5
37 changes: 21 additions & 16 deletions src/components/Tokens/TokenDetails/index.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
import { Trans } from '@lingui/macro'
import { Trace } from '@uniswap/analytics'
import { InterfacePageName } from '@uniswap/analytics-events'
import { Field } from '@uniswap/widgets'
import { useWeb3React } from '@web3-react/core'
import CurrencyLogo from 'components/Logo/CurrencyLogo'
import { AboutSection } from 'components/Tokens/TokenDetails/About'
Expand Down Expand Up @@ -34,9 +33,11 @@ import { Swap } from 'pages/Swap'
import { useCallback, useMemo, useState, useTransition } from 'react'
import { ArrowLeft } from 'react-feather'
import { useNavigate } from 'react-router-dom'
import { Field } from 'state/swap/actions'
import { SwapState } from 'state/swap/reducer'
import styled from 'styled-components/macro'
import { isAddress } from 'utils'
import { addressesAreEquivalent } from 'utils/addressesAreEquivalent'

import { OnChangeTimePeriod } from './ChartSection'
import InvalidTokenDetails from './InvalidTokenDetails'
Expand Down Expand Up @@ -145,22 +146,26 @@ export default function TokenDetails({
useOnGlobalChainSwitch(navigateToTokenForChain)

const handleCurrencyChange = useCallback(
(tokens: Partial<SwapState>) => {
if (tokens[Field.INPUT]?.currencyId !== address && tokens[Field.OUTPUT]?.currencyId !== address) {
const newDefaultTokenID = tokens[Field.OUTPUT]?.currencyId ?? tokens[Field.INPUT]?.currencyId
startTokenTransition(() =>
navigate(
getTokenDetailsURL({
address: newDefaultTokenID === 'ETH' ? 'NATIVE' : newDefaultTokenID,
chain,
inputAddress:
tokens[Field.INPUT] && tokens[Field.INPUT]?.currencyId !== newDefaultTokenID
? tokens[Field.INPUT]?.currencyId
: null,
})
)
)
(tokens: Pick<SwapState, Field.INPUT | Field.OUTPUT>) => {
if (
addressesAreEquivalent(tokens[Field.INPUT]?.currencyId, address) ||
addressesAreEquivalent(tokens[Field.OUTPUT]?.currencyId, address)
) {
return
}
const newDefaultTokenID = tokens[Field.OUTPUT]?.currencyId ?? tokens[Field.INPUT]?.currencyId
startTokenTransition(() =>
navigate(
getTokenDetailsURL({
address: newDefaultTokenID === 'ETH' ? 'NATIVE' : newDefaultTokenID,
just-toby marked this conversation as resolved.
Show resolved Hide resolved
chain,
inputAddress:
tokens[Field.INPUT] && tokens[Field.INPUT]?.currencyId !== newDefaultTokenID
just-toby marked this conversation as resolved.
Show resolved Hide resolved
? tokens[Field.INPUT]?.currencyId
: null,
})
)
)
},
[address, chain, navigate]
)
Expand Down
1 change: 1 addition & 0 deletions src/components/Widget/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,7 @@ interface WidgetProps {
onReviewSwapClick?: OnReviewSwapClick
}

// TODO: Remove this component once the TDP is fully migrated to the swap component.
// eslint-disable-next-line import/no-unused-modules
just-toby marked this conversation as resolved.
Show resolved Hide resolved
export default function Widget({
defaultTokens,
Expand Down
2 changes: 1 addition & 1 deletion src/pages/Swap/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -166,7 +166,7 @@ export function Swap({
className?: string
prefilledState?: Partial<SwapState>
defaultChainId?: SupportedChainId
onCurrencyChange?: (selected: Partial<SwapState>) => void
onCurrencyChange?: (selected: Pick<SwapState, Field.INPUT | Field.OUTPUT>) => void
}) {
const { account, chainId, connector } = useWeb3React()
just-toby marked this conversation as resolved.
Show resolved Hide resolved
const loadedUrlParams = useDefaultsFromURLSearch()
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

it still doesn't make sense to me that the URL parsing happens from within the shared component instead of on the page

imo this should be handled at the page level and the addresses should be passed in as part of prefilledState

Expand Down
2 changes: 1 addition & 1 deletion src/utils/addressesAreEquivalent.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
export function addressesAreEquivalent(a?: string, b?: string) {
export function addressesAreEquivalent(a?: string | null, b?: string | null) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

nit: I am generally confused with nulls vs undefined in our codebase sometimes, when this can be undefined, and when this can be null?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

i think this function should allow nullish / undefined values, but it should be required to pass 2 arguments.

if (!a || !b) return false
return a === b || a.toLowerCase() === b.toLowerCase()
}