Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
I
interface
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
LuckySwap
interface
Commits
37cf492d
Unverified
Commit
37cf492d
authored
Jun 16, 2021
by
Yuta Sugimura
Committed by
GitHub
Jun 16, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fix: Add SwitchLocaleLink to a page where it does not exist (#1867)
parent
9e93f809
Changes
6
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
900 additions
and
874 deletions
+900
-874
index.tsx
src/pages/AddLiquidity/index.tsx
+383
-374
index.tsx
src/pages/AddLiquidityV2/index.tsx
+3
-0
index.tsx
src/pages/MigrateV2/index.tsx
+69
-65
PositionPage.tsx
src/pages/Pool/PositionPage.tsx
+322
-318
v2.tsx
src/pages/Pool/v2.tsx
+2
-0
index.tsx
src/pages/PoolFinder/index.tsx
+121
-117
No files found.
src/pages/AddLiquidity/index.tsx
View file @
37cf492d
This diff is collapsed.
Click to expand it.
src/pages/AddLiquidityV2/index.tsx
View file @
37cf492d
...
...
@@ -42,6 +42,7 @@ import { ConfirmAddModalBottom } from './ConfirmAddModalBottom'
import
{
currencyId
}
from
'
../../utils/currencyId
'
import
{
PoolPriceBar
}
from
'
./PoolPriceBar
'
import
UnsupportedCurrencyFooter
from
'
components/swap/UnsupportedCurrencyFooter
'
import
{
SwitchLocaleLink
}
from
'
components/SwitchLocaleLink
'
import
{
t
,
Trans
}
from
'
@lingui/macro
'
const
DEFAULT_ADD_V2_SLIPPAGE_TOLERANCE
=
new
Percent
(
50
,
10
_000
)
...
...
@@ -485,6 +486,8 @@ export default function AddLiquidity({
</
AutoColumn
>
</
Wrapper
>
</
AppBody
>
<
SwitchLocaleLink
/>
{
!
addIsUnsupported
?
(
pair
&&
!
noLiquidity
&&
pairState
!==
PairState
.
INVALID
?
(
<
AutoColumn
style=
{
{
minWidth
:
'
20rem
'
,
width
:
'
100%
'
,
maxWidth
:
'
400px
'
,
marginTop
:
'
1rem
'
}
}
>
...
...
src/pages/MigrateV2/index.tsx
View file @
37cf492d
...
...
@@ -16,6 +16,7 @@ import { Dots } from '../../components/swap/styleds'
import
{
toV2LiquidityToken
,
useTrackedTokenPairs
}
from
'
../../state/user/hooks
'
import
MigrateV2PositionCard
from
'
components/PositionCard/V2
'
import
MigrateSushiPositionCard
from
'
components/PositionCard/Sushi
'
import
{
SwitchLocaleLink
}
from
'
components/SwitchLocaleLink
'
import
{
PairState
,
useV2Pairs
}
from
'
hooks/useV2Pairs
'
import
{
getCreate2Address
}
from
'
@ethersproject/address
'
import
{
pack
,
keccak256
}
from
'
@ethersproject/solidity
'
...
...
@@ -110,73 +111,76 @@ export default function MigrateV2() {
const
v2IsLoading
=
fetchingPairBalances
||
v2Pairs
.
some
(([
pairState
])
=>
pairState
===
PairState
.
LOADING
)
return
(
<
BodyWrapper
style=
{
{
padding
:
24
}
}
>
<
AutoColumn
gap=
"16px"
>
<
AutoRow
style=
{
{
alignItems
:
'
center
'
,
justifyContent
:
'
space-between
'
}
}
gap=
"8px"
>
<
BackArrow
to=
"/pool/v2"
/>
<
TYPE
.
mediumHeader
>
<
Trans
>
Migrate V2 Liquidity
</
Trans
>
</
TYPE
.
mediumHeader
>
<
div
>
<
QuestionHelper
text=
{
<
Trans
>
Migrate your liquidity tokens from Uniswap V2 to Uniswap V3.
</
Trans
>
}
/>
</
div
>
</
AutoRow
>
<
TYPE
.
body
style=
{
{
marginBottom
:
8
,
fontWeight
:
400
}
}
>
<
Trans
>
For each pool shown below, click migrate to remove your liquidity from Uniswap V2 and deposit it into
Uniswap V3.
</
Trans
>
</
TYPE
.
body
>
{
!
account
?
(
<
LightCard
padding=
"40px"
>
<
TYPE
.
body
color=
{
theme
.
text3
}
textAlign=
"center"
>
<
Trans
>
Connect to a wallet to view your V2 liquidity.
</
Trans
>
</
TYPE
.
body
>
</
LightCard
>
)
:
v2IsLoading
?
(
<
LightCard
padding=
"40px"
>
<
TYPE
.
body
color=
{
theme
.
text3
}
textAlign=
"center"
>
<
Dots
>
<
Trans
>
Loading
</
Trans
>
</
Dots
>
</
TYPE
.
body
>
</
LightCard
>
)
:
v2Pairs
.
filter
(([,
pair
])
=>
!!
pair
).
length
>
0
?
(
<>
{
v2Pairs
.
filter
(([,
pair
])
=>
!!
pair
)
.
map
(([,
pair
])
=>
(
<
MigrateV2PositionCard
key=
{
(
pair
as
Pair
).
liquidityToken
.
address
}
pair=
{
pair
as
Pair
}
/>
))
}
{
tokenPairsWithSushiBalance
.
map
(({
sushiLiquidityToken
,
tokens
})
=>
{
return
(
<
MigrateSushiPositionCard
key=
{
(
sushiLiquidityToken
as
Token
).
address
}
tokenA=
{
tokens
[
0
]
}
tokenB=
{
tokens
[
1
]
}
liquidityToken=
{
sushiLiquidityToken
as
Token
}
/>
)
})
}
</>
)
:
(
<
EmptyState
message=
{
<
Trans
>
No V2 Liquidity found.
</
Trans
>
}
/>
)
}
<
AutoColumn
justify=
{
'
center
'
}
gap=
"md"
>
<
Text
textAlign=
"center"
fontSize=
{
14
}
style=
{
{
padding
:
'
.5rem 0 .5rem 0
'
}
}
>
<>
<
BodyWrapper
style=
{
{
padding
:
24
}
}
>
<
AutoColumn
gap=
"16px"
>
<
AutoRow
style=
{
{
alignItems
:
'
center
'
,
justifyContent
:
'
space-between
'
}
}
gap=
"8px"
>
<
BackArrow
to=
"/pool/v2"
/>
<
TYPE
.
mediumHeader
>
<
Trans
>
Migrate V2 Liquidity
</
Trans
>
</
TYPE
.
mediumHeader
>
<
div
>
<
QuestionHelper
text=
{
<
Trans
>
Migrate your liquidity tokens from Uniswap V2 to Uniswap V3.
</
Trans
>
}
/>
</
div
>
</
AutoRow
>
<
TYPE
.
body
style=
{
{
marginBottom
:
8
,
fontWeight
:
400
}
}
>
<
Trans
>
Don’t see one of your v2 positions?
{
'
'
}
<
StyledInternalLink
id=
"import-pool-link"
to=
{
'
/find?origin=/migrate/v2
'
}
>
Import it.
</
StyledInternalLink
>
For each pool shown below, click migrate to remove your liquidity from Uniswap V2 and deposit it into
Uniswap V3.
</
Trans
>
</
Text
>
</
TYPE
.
body
>
{
!
account
?
(
<
LightCard
padding=
"40px"
>
<
TYPE
.
body
color=
{
theme
.
text3
}
textAlign=
"center"
>
<
Trans
>
Connect to a wallet to view your V2 liquidity.
</
Trans
>
</
TYPE
.
body
>
</
LightCard
>
)
:
v2IsLoading
?
(
<
LightCard
padding=
"40px"
>
<
TYPE
.
body
color=
{
theme
.
text3
}
textAlign=
"center"
>
<
Dots
>
<
Trans
>
Loading
</
Trans
>
</
Dots
>
</
TYPE
.
body
>
</
LightCard
>
)
:
v2Pairs
.
filter
(([,
pair
])
=>
!!
pair
).
length
>
0
?
(
<>
{
v2Pairs
.
filter
(([,
pair
])
=>
!!
pair
)
.
map
(([,
pair
])
=>
(
<
MigrateV2PositionCard
key=
{
(
pair
as
Pair
).
liquidityToken
.
address
}
pair=
{
pair
as
Pair
}
/>
))
}
{
tokenPairsWithSushiBalance
.
map
(({
sushiLiquidityToken
,
tokens
})
=>
{
return
(
<
MigrateSushiPositionCard
key=
{
(
sushiLiquidityToken
as
Token
).
address
}
tokenA=
{
tokens
[
0
]
}
tokenB=
{
tokens
[
1
]
}
liquidityToken=
{
sushiLiquidityToken
as
Token
}
/>
)
})
}
</>
)
:
(
<
EmptyState
message=
{
<
Trans
>
No V2 Liquidity found.
</
Trans
>
}
/>
)
}
<
AutoColumn
justify=
{
'
center
'
}
gap=
"md"
>
<
Text
textAlign=
"center"
fontSize=
{
14
}
style=
{
{
padding
:
'
.5rem 0 .5rem 0
'
}
}
>
<
Trans
>
Don’t see one of your v2 positions?
{
'
'
}
<
StyledInternalLink
id=
"import-pool-link"
to=
{
'
/find?origin=/migrate/v2
'
}
>
Import it.
</
StyledInternalLink
>
</
Trans
>
</
Text
>
</
AutoColumn
>
</
AutoColumn
>
</
AutoColumn
>
</
BodyWrapper
>
</
BodyWrapper
>
<
SwitchLocaleLink
/>
</>
)
}
src/pages/Pool/PositionPage.tsx
View file @
37cf492d
This diff is collapsed.
Click to expand it.
src/pages/Pool/v2.tsx
View file @
37cf492d
...
...
@@ -19,6 +19,7 @@ import { useV2Pairs } from '../../hooks/useV2Pairs'
import
{
toV2LiquidityToken
,
useTrackedTokenPairs
}
from
'
../../state/user/hooks
'
import
{
Dots
}
from
'
../../components/swap/styleds
'
import
{
CardSection
,
DataCard
,
CardNoise
,
CardBGImage
}
from
'
../../components/earn/styled
'
import
{
SwitchLocaleLink
}
from
'
../../components/SwitchLocaleLink
'
import
{
useStakingInfo
}
from
'
../../state/stake/hooks
'
import
{
BIG_INT_ZERO
}
from
'
../../constants/misc
'
import
{
Pair
}
from
'
@uniswap/v2-sdk
'
...
...
@@ -256,6 +257,7 @@ export default function Pool() {
</
AutoColumn
>
</
AutoColumn
>
</
PageWrapper
>
<
SwitchLocaleLink
/>
</>
)
}
src/pages/PoolFinder/index.tsx
View file @
37cf492d
...
...
@@ -11,6 +11,7 @@ import { FindPoolTabs } from '../../components/NavigationTabs'
import
{
MinimalPositionCard
}
from
'
../../components/PositionCard
'
import
Row
from
'
../../components/Row
'
import
CurrencySearchModal
from
'
../../components/SearchModal/CurrencySearchModal
'
import
{
SwitchLocaleLink
}
from
'
../../components/SwitchLocaleLink
'
import
{
ExtendedEther
}
from
'
../../constants/tokens
'
import
{
PairState
,
useV2Pair
}
from
'
../../hooks/useV2Pairs
'
import
{
useActiveWeb3React
}
from
'
../../hooks/web3
'
...
...
@@ -93,136 +94,139 @@ export default function PoolFinder() {
)
return
(
<
AppBody
>
<
FindPoolTabs
origin=
{
query
.
get
(
'
origin
'
)
??
'
/pool/v2
'
}
/>
<
AutoColumn
style=
{
{
padding
:
'
1rem
'
}
}
gap=
"md"
>
<
BlueCard
>
<
AutoColumn
gap=
"10px"
>
<
TYPE
.
link
fontWeight=
{
400
}
color=
{
'
primaryText1
'
}
>
<
Trans
>
<
b
>
Tip:
</
b
>
Use this tool to find v2 pools that don
'
t automatically appear in the interface.
</
Trans
>
</
TYPE
.
link
>
</
AutoColumn
>
</
BlueCard
>
<
ButtonDropdownLight
onClick=
{
()
=>
{
setShowSearch
(
true
)
setActiveField
(
Fields
.
TOKEN0
)
}
}
>
{
currency0
?
(
<
Row
>
<
CurrencyLogo
currency=
{
currency0
}
/>
<
Text
fontWeight=
{
500
}
fontSize=
{
20
}
marginLeft=
{
'
12px
'
}
>
{
currency0
.
symbol
}
</
Text
>
</
Row
>
)
:
(
<
Text
fontWeight=
{
500
}
fontSize=
{
20
}
marginLeft=
{
'
12px
'
}
>
<
Trans
>
Select a token
</
Trans
>
</
Text
>
)
}
</
ButtonDropdownLight
>
<
ColumnCenter
>
<
Plus
size=
"16"
color=
"#888D9B"
/>
</
ColumnCenter
>
<
ButtonDropdownLight
onClick=
{
()
=>
{
setShowSearch
(
true
)
setActiveField
(
Fields
.
TOKEN1
)
}
}
>
{
currency1
?
(
<
Row
>
<
CurrencyLogo
currency=
{
currency1
}
/>
<>
<
AppBody
>
<
FindPoolTabs
origin=
{
query
.
get
(
'
origin
'
)
??
'
/pool/v2
'
}
/>
<
AutoColumn
style=
{
{
padding
:
'
1rem
'
}
}
gap=
"md"
>
<
BlueCard
>
<
AutoColumn
gap=
"10px"
>
<
TYPE
.
link
fontWeight=
{
400
}
color=
{
'
primaryText1
'
}
>
<
Trans
>
<
b
>
Tip:
</
b
>
Use this tool to find v2 pools that don
'
t automatically appear in the interface.
</
Trans
>
</
TYPE
.
link
>
</
AutoColumn
>
</
BlueCard
>
<
ButtonDropdownLight
onClick=
{
()
=>
{
setShowSearch
(
true
)
setActiveField
(
Fields
.
TOKEN0
)
}
}
>
{
currency0
?
(
<
Row
>
<
CurrencyLogo
currency=
{
currency0
}
/>
<
Text
fontWeight=
{
500
}
fontSize=
{
20
}
marginLeft=
{
'
12px
'
}
>
{
currency0
.
symbol
}
</
Text
>
</
Row
>
)
:
(
<
Text
fontWeight=
{
500
}
fontSize=
{
20
}
marginLeft=
{
'
12px
'
}
>
{
currency1
.
symbol
}
<
Trans
>
Select a token
</
Trans
>
</
Text
>
</
Row
>
)
:
(
<
Text
fontWeight=
{
500
}
fontSize=
{
20
}
marginLeft=
{
'
12px
'
}
>
<
Trans
>
Select a token
</
Trans
>
</
Text
>
)
}
</
ButtonDropdownLight
>
)
}
</
ButtonDropdownLight
>
{
hasPosition
&&
(
<
ColumnCenter
style=
{
{
justifyItems
:
'
center
'
,
backgroundColor
:
''
,
padding
:
'
12px 0px
'
,
borderRadius
:
'
12px
'
}
}
>
<
Text
textAlign=
"center"
fontWeight=
{
500
}
>
<
Trans
>
Pool Found!
</
Trans
>
</
Text
>
<
StyledInternalLink
to=
{
`/pool/v2`
}
>
<
Text
textAlign=
"center"
>
<
Trans
>
Manage this pool.
</
Trans
>
</
Text
>
</
StyledInternalLink
>
<
ColumnCenter
>
<
Plus
size=
"16"
color=
"#888D9B"
/>
</
ColumnCenter
>
)
}
{
currency0
&&
currency1
?
(
pairState
===
PairState
.
EXISTS
?
(
hasPosition
&&
pair
?
(
<
MinimalPositionCard
pair=
{
pair
}
border=
"1px solid #CED0D9"
/>
<
ButtonDropdownLight
onClick=
{
()
=>
{
setShowSearch
(
true
)
setActiveField
(
Fields
.
TOKEN1
)
}
}
>
{
currency1
?
(
<
Row
>
<
CurrencyLogo
currency=
{
currency1
}
/>
<
Text
fontWeight=
{
500
}
fontSize=
{
20
}
marginLeft=
{
'
12px
'
}
>
{
currency1
.
symbol
}
</
Text
>
</
Row
>
)
:
(
<
Text
fontWeight=
{
500
}
fontSize=
{
20
}
marginLeft=
{
'
12px
'
}
>
<
Trans
>
Select a token
</
Trans
>
</
Text
>
)
}
</
ButtonDropdownLight
>
{
hasPosition
&&
(
<
ColumnCenter
style=
{
{
justifyItems
:
'
center
'
,
backgroundColor
:
''
,
padding
:
'
12px 0px
'
,
borderRadius
:
'
12px
'
}
}
>
<
Text
textAlign=
"center"
fontWeight=
{
500
}
>
<
Trans
>
Pool Found!
</
Trans
>
</
Text
>
<
StyledInternalLink
to=
{
`/pool/v2`
}
>
<
Text
textAlign=
"center"
>
<
Trans
>
Manage this pool.
</
Trans
>
</
Text
>
</
StyledInternalLink
>
</
ColumnCenter
>
)
}
{
currency0
&&
currency1
?
(
pairState
===
PairState
.
EXISTS
?
(
hasPosition
&&
pair
?
(
<
MinimalPositionCard
pair=
{
pair
}
border=
"1px solid #CED0D9"
/>
)
:
(
<
LightCard
padding=
"45px 10px"
>
<
AutoColumn
gap=
"sm"
justify=
"center"
>
<
Text
textAlign=
"center"
>
<
Trans
>
You don’t have liquidity in this pool yet.
</
Trans
>
</
Text
>
<
StyledInternalLink
to=
{
`/add/${currencyId(currency0)}/${currencyId(currency1)}`
}
>
<
Text
textAlign=
"center"
>
<
Trans
>
Add liquidity.
</
Trans
>
</
Text
>
</
StyledInternalLink
>
</
AutoColumn
>
</
LightCard
>
)
)
:
validPairNoLiquidity
?
(
<
LightCard
padding=
"45px 10px"
>
<
AutoColumn
gap=
"sm"
justify=
"center"
>
<
Text
textAlign=
"center"
>
<
Trans
>
You don’t have liquidity in this pool yet
.
</
Trans
>
<
Trans
>
No pool found
.
</
Trans
>
</
Text
>
<
StyledInternalLink
to=
{
`/add/${currencyId(currency0)}/${currencyId(currency1)}`
}
>
<
Text
textAlign=
"center"
>
<
Trans
>
Add liquidity.
</
Trans
>
</
Text
>
<
Trans
>
Create pool.
</
Trans
>
</
StyledInternalLink
>
</
AutoColumn
>
</
LightCard
>
)
)
:
validPairNoLiquidity
?
(
<
LightCard
padding=
"45px 10px"
>
<
AutoColumn
gap=
"sm"
justify=
"center"
>
<
Text
textAlign=
"center"
>
<
Trans
>
No pool found.
</
Trans
>
</
Text
>
<
StyledInternalLink
to=
{
`/add/${currencyId(currency0)}/${currencyId(currency1)}`
}
>
<
Trans
>
Create pool.
</
Trans
>
</
StyledInternalLink
>
</
AutoColumn
>
</
LightCard
>
)
:
pairState
===
PairState
.
INVALID
?
(
<
LightCard
padding=
"45px 10px"
>
<
AutoColumn
gap=
"sm"
justify=
"center"
>
<
Text
textAlign=
"center"
fontWeight=
{
500
}
>
<
Trans
>
Invalid pair.
</
Trans
>
</
Text
>
</
AutoColumn
>
</
LightCard
>
)
:
pairState
===
PairState
.
LOADING
?
(
<
LightCard
padding=
"45px 10px"
>
<
AutoColumn
gap=
"sm"
justify=
"center"
>
<
Text
textAlign=
"center"
>
<
Trans
>
Loading
</
Trans
>
<
Dots
/>
</
Text
>
</
AutoColumn
>
</
LightCard
>
)
:
null
)
:
(
prerequisiteMessage
)
}
</
AutoColumn
>
<
CurrencySearchModal
isOpen=
{
showSearch
}
onCurrencySelect=
{
handleCurrencySelect
}
onDismiss=
{
handleSearchDismiss
}
showCommonBases
selectedCurrency=
{
(
activeField
===
Fields
.
TOKEN0
?
currency1
:
currency0
)
??
undefined
}
/>
</
AppBody
>
)
:
pairState
===
PairState
.
INVALID
?
(
<
LightCard
padding=
"45px 10px"
>
<
AutoColumn
gap=
"sm"
justify=
"center"
>
<
Text
textAlign=
"center"
fontWeight=
{
500
}
>
<
Trans
>
Invalid pair.
</
Trans
>
</
Text
>
</
AutoColumn
>
</
LightCard
>
)
:
pairState
===
PairState
.
LOADING
?
(
<
LightCard
padding=
"45px 10px"
>
<
AutoColumn
gap=
"sm"
justify=
"center"
>
<
Text
textAlign=
"center"
>
<
Trans
>
Loading
</
Trans
>
<
Dots
/>
</
Text
>
</
AutoColumn
>
</
LightCard
>
)
:
null
)
:
(
prerequisiteMessage
)
}
</
AutoColumn
>
<
CurrencySearchModal
isOpen=
{
showSearch
}
onCurrencySelect=
{
handleCurrencySelect
}
onDismiss=
{
handleSearchDismiss
}
showCommonBases
selectedCurrency=
{
(
activeField
===
Fields
.
TOKEN0
?
currency1
:
currency0
)
??
undefined
}
/>
</
AppBody
>
<
SwitchLocaleLink
/>
</>
)
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment