mirror of
https://github.com/oceanprotocol/market.git
synced 2024-12-02 05:57:29 +01:00
add creator liquidity (#178)
* add creator liquidity Signed-off-by: mihaisc <mihai.scarlat@smartcontrol.ro> * remove comments Signed-off-by: mihaisc <mihai.scarlat@smartcontrol.ro> * check price update Signed-off-by: mihaisc <mihai.scarlat@smartcontrol.ro>
This commit is contained in:
parent
e96d782917
commit
5b3002fd82
@ -54,23 +54,40 @@ export default function Pool({ ddo }: { ddo: DDO }): ReactElement {
|
|||||||
const [showAdd, setShowAdd] = useState(false)
|
const [showAdd, setShowAdd] = useState(false)
|
||||||
const [showRemove, setShowRemove] = useState(false)
|
const [showRemove, setShowRemove] = useState(false)
|
||||||
|
|
||||||
|
const [hasAddedLiquidity, setHasAddedLiquidity] = useState(false)
|
||||||
|
const [poolShare, setPoolShare] = useState<string>()
|
||||||
|
const [totalUserLiquidityInOcean, setTotalUserLiquidityInOcean] = useState(0)
|
||||||
|
const [totalLiquidityInOcean, setTotalLiquidityInOcean] = useState(0)
|
||||||
|
|
||||||
|
const [
|
||||||
|
creatorTotalLiquidityInOcean,
|
||||||
|
setCreatorTotalLiquidityInOcean
|
||||||
|
] = useState(0)
|
||||||
|
const [creatorLiquidity, setCreatorLiquidity] = useState<Balance>()
|
||||||
|
const [creatorPoolTokens, setCreatorPoolTokens] = useState<string>()
|
||||||
|
const [creatorPoolShare, setCreatorPoolShare] = useState<string>()
|
||||||
// the purpose of the value is just to trigger the effect
|
// the purpose of the value is just to trigger the effect
|
||||||
const [refreshPool, setRefreshPool] = useState(false)
|
const [refreshPool, setRefreshPool] = useState(false)
|
||||||
// TODO: put all these variables behind some useEffect
|
|
||||||
// to prevent unneccessary updating on every render
|
useEffect(() => {
|
||||||
const hasAddedLiquidity =
|
const hasAddedLiquidity =
|
||||||
userLiquidity && (userLiquidity.ocean > 0 || userLiquidity.datatoken > 0)
|
userLiquidity && (userLiquidity.ocean > 0 || userLiquidity.datatoken > 0)
|
||||||
|
setHasAddedLiquidity(hasAddedLiquidity)
|
||||||
|
|
||||||
const poolShare =
|
const poolShare =
|
||||||
price?.ocean &&
|
price?.ocean &&
|
||||||
price?.datatoken &&
|
price?.datatoken &&
|
||||||
userLiquidity &&
|
userLiquidity &&
|
||||||
((Number(poolTokens) / Number(totalPoolTokens)) * 100).toFixed(2)
|
((Number(poolTokens) / Number(totalPoolTokens)) * 100).toFixed(2)
|
||||||
|
setPoolShare(poolShare)
|
||||||
|
|
||||||
const totalUserLiquidityInOcean =
|
const totalUserLiquidityInOcean =
|
||||||
userLiquidity?.ocean + userLiquidity?.datatoken * price?.value
|
userLiquidity?.ocean + userLiquidity?.datatoken * price?.value
|
||||||
|
setTotalUserLiquidityInOcean(totalUserLiquidityInOcean)
|
||||||
|
|
||||||
const totalLiquidityInOcean = price?.ocean + price?.datatoken * price?.value
|
const totalLiquidityInOcean = price?.ocean + price?.datatoken * price?.value
|
||||||
|
setTotalLiquidityInOcean(totalLiquidityInOcean)
|
||||||
|
}, [userLiquidity, price])
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (!ocean || !accountId || !price) return
|
if (!ocean || !accountId || !price) return
|
||||||
@ -108,6 +125,43 @@ export default function Pool({ ddo }: { ddo: DDO }): ReactElement {
|
|||||||
|
|
||||||
setUserLiquidity(userLiquidity)
|
setUserLiquidity(userLiquidity)
|
||||||
|
|
||||||
|
//
|
||||||
|
// Get everything the creator put into the pool
|
||||||
|
//
|
||||||
|
|
||||||
|
const creatorPoolTokens = await ocean.pool.sharesBalance(
|
||||||
|
ddo.publicKey[0].owner,
|
||||||
|
price.address
|
||||||
|
)
|
||||||
|
setCreatorPoolTokens(creatorPoolTokens)
|
||||||
|
|
||||||
|
// calculate creator's provided liquidity based on pool tokens
|
||||||
|
|
||||||
|
const creatorOceanBalance =
|
||||||
|
(Number(creatorPoolTokens) / Number(totalPoolTokens)) * price.ocean
|
||||||
|
|
||||||
|
const creatorDtBalance =
|
||||||
|
(Number(creatorPoolTokens) / Number(totalPoolTokens)) *
|
||||||
|
price.datatoken
|
||||||
|
|
||||||
|
const creatorLiquidity = {
|
||||||
|
ocean: creatorOceanBalance,
|
||||||
|
datatoken: creatorDtBalance
|
||||||
|
}
|
||||||
|
setCreatorLiquidity(creatorLiquidity)
|
||||||
|
|
||||||
|
const totalCreatorLiquidityInOcean =
|
||||||
|
creatorLiquidity?.ocean + creatorLiquidity?.datatoken * price?.value
|
||||||
|
setCreatorTotalLiquidityInOcean(totalCreatorLiquidityInOcean)
|
||||||
|
|
||||||
|
const creatorPoolShare =
|
||||||
|
price?.ocean &&
|
||||||
|
price?.datatoken &&
|
||||||
|
creatorLiquidity &&
|
||||||
|
((Number(creatorPoolTokens) / Number(totalPoolTokens)) * 100).toFixed(
|
||||||
|
2
|
||||||
|
)
|
||||||
|
setCreatorPoolShare(creatorPoolShare)
|
||||||
// Get swap fee
|
// Get swap fee
|
||||||
// swapFee is tricky: to get 0.1% you need to convert from 0.001
|
// swapFee is tricky: to get 0.1% you need to convert from 0.001
|
||||||
const swapFee = await ocean.pool.getSwapFee(price.address)
|
const swapFee = await ocean.pool.getSwapFee(price.address)
|
||||||
@ -123,6 +177,7 @@ export default function Pool({ ddo }: { ddo: DDO }): ReactElement {
|
|||||||
setRefreshPool(!refreshPool)
|
setRefreshPool(!refreshPool)
|
||||||
await refreshPrice()
|
await refreshPrice()
|
||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
{showAdd ? (
|
{showAdd ? (
|
||||||
@ -184,6 +239,17 @@ export default function Pool({ ddo }: { ddo: DDO }): ReactElement {
|
|||||||
<Token symbol="% of pool" balance={poolShare} noIcon />
|
<Token symbol="% of pool" balance={poolShare} noIcon />
|
||||||
</TokenList>
|
</TokenList>
|
||||||
|
|
||||||
|
<TokenList
|
||||||
|
title="Pool Creator Liquidity"
|
||||||
|
ocean={`${creatorLiquidity?.ocean}`}
|
||||||
|
dt={`${creatorLiquidity?.datatoken}`}
|
||||||
|
dtSymbol={dtSymbol}
|
||||||
|
poolShares={creatorPoolTokens}
|
||||||
|
conversion={creatorTotalLiquidityInOcean}
|
||||||
|
>
|
||||||
|
<Token symbol="% of pool" balance={creatorPoolShare} noIcon />
|
||||||
|
</TokenList>
|
||||||
|
|
||||||
<TokenList
|
<TokenList
|
||||||
title="Pool Statistics"
|
title="Pool Statistics"
|
||||||
ocean={`${price?.ocean}`}
|
ocean={`${price?.ocean}`}
|
||||||
|
Loading…
Reference in New Issue
Block a user