1
0
mirror of https://github.com/oceanprotocol/market.git synced 2024-12-02 05:57:29 +01:00

small PoolShares refactor

This commit is contained in:
Matthias Kretschmann 2021-09-02 19:35:49 +02:00
parent 30f262de33
commit fe065aea58
Signed by: m
GPG Key ID: 606EEEF3C479A91F
2 changed files with 71 additions and 62 deletions

View File

@ -30,31 +30,31 @@
} }
} }
.yourLiquidity { .userLiquidity {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
align-items: flex-end; align-items: flex-end;
} }
.yourLiquidity [class*='Conversion-module--'] { .userLiquidity [class*='Conversion-module--'] {
margin-bottom: calc(var(--spacer) / 8); margin-bottom: calc(var(--spacer) / 8);
} }
.yourLiquidity [class*='Conversion-module--'] strong { .userLiquidity [class*='Conversion-module--'] strong {
font-size: var(--font-size-base); font-size: var(--font-size-base);
} }
.yourLiquidity [class*='Token-module--token'] { .userLiquidity [class*='Token-module--token'] {
display: flex; display: flex;
align-items: center; align-items: center;
justify-content: flex-end; justify-content: flex-end;
margin-bottom: calc(var(--spacer) / 8); margin-bottom: calc(var(--spacer) / 8);
} }
.yourLiquidity [class*='Token-module--token'] div { .userLiquidity [class*='Token-module--token'] div {
font-size: var(--font-size-small); font-size: var(--font-size-small);
} }
.yourLiquidity [class*='Token-module--icon'] { .userLiquidity [class*='Token-module--icon'] {
display: none; display: none;
} }

View File

@ -1,4 +1,4 @@
import React, { ReactElement, useEffect, useState } from 'react' import React, { ReactElement, useCallback, useEffect, useState } from 'react'
import Table from '../../../atoms/Table' import Table from '../../../atoms/Table'
import Conversion from '../../../atoms/Price/Conversion' import Conversion from '../../../atoms/Price/Conversion'
import styles from './PoolShares.module.css' import styles from './PoolShares.module.css'
@ -102,7 +102,7 @@ function Liquidity({ row, type }: { row: Asset; type: string }) {
dataTokenBalance = row.poolShare.poolId.datatokenReserve.toString() dataTokenBalance = row.poolShare.poolId.datatokenReserve.toString()
} }
return ( return (
<div className={styles.yourLiquidity}> <div className={styles.userLiquidity}>
<Conversion <Conversion
price={price} price={price}
className={styles.totalLiquidity} className={styles.totalLiquidity}
@ -146,7 +146,7 @@ const columns = [
} }
}, },
{ {
name: 'Your Liquidity', name: 'Liquidity',
selector: function getAssetRow(row: Asset) { selector: function getAssetRow(row: Asset) {
return <Liquidity row={row} type="user" /> return <Liquidity row={row} type="user" />
}, },
@ -161,6 +161,43 @@ const columns = [
} }
] ]
async function getPoolSharesData(accountId: string, chainIds: number[]) {
const variables = { user: accountId?.toLowerCase() }
const data: PoolShare[] = []
const result = await fetchDataForMultipleChains(
poolSharesQuery,
variables,
chainIds
)
for (let i = 0; i < result.length; i++) {
result[i].poolShares.forEach((poolShare: PoolShare) => {
data.push(poolShare)
})
}
return data
}
async function getPoolSharesAssets(data: PoolShare[]) {
const assetList: Asset[] = []
const source = axios.CancelToken.source()
for (let i = 0; i < data.length; i++) {
const did = web3.utils
.toChecksumAddress(data[i].poolId.datatokenAddress)
.replace('0x', 'did:op:')
const ddo = await retrieveDDO(did, source.token)
const userLiquidity = calculateUserLiquidity(data[i])
assetList.push({
poolShare: data[i],
userLiquidity: userLiquidity,
networkId: ddo?.chainId,
createTime: data[i].poolId.createTime
})
}
const assets = assetList.sort((a, b) => b.createTime - a.createTime)
return assets
}
export default function PoolShares({ export default function PoolShares({
accountId accountId
}: { }: {
@ -172,33 +209,16 @@ export default function PoolShares({
const [dataFetchInterval, setDataFetchInterval] = useState<NodeJS.Timeout>() const [dataFetchInterval, setDataFetchInterval] = useState<NodeJS.Timeout>()
const { chainIds } = useUserPreferences() const { chainIds } = useUserPreferences()
async function fetchPoolSharesData() { const refetchPoolSharesData = useCallback(() => {
const variables = { user: accountId?.toLowerCase() } if (dataFetchInterval) return
const shares: PoolShare[] = []
const result = await fetchDataForMultipleChains(
poolSharesQuery,
variables,
chainIds
)
for (let i = 0; i < result.length; i++) {
result[i].poolShares.forEach((poolShare: PoolShare) => {
shares.push(poolShare)
})
}
if (JSON.stringify(data) !== JSON.stringify(shares)) {
setData(shares)
}
}
function refetchPoolShares() {
if (!dataFetchInterval) {
setDataFetchInterval( setDataFetchInterval(
setInterval(function () { setInterval(async () => {
fetchPoolSharesData() const newData = await getPoolSharesData(accountId, chainIds)
setData(newData)
}, REFETCH_INTERVAL) }, REFETCH_INTERVAL)
) )
} }, [dataFetchInterval, chainIds, accountId])
}
useEffect(() => { useEffect(() => {
return () => { return () => {
@ -207,43 +227,32 @@ export default function PoolShares({
}, [dataFetchInterval]) }, [dataFetchInterval])
useEffect(() => { useEffect(() => {
async function getShares() { async function init() {
const assetList: Asset[] = []
const source = axios.CancelToken.source()
try {
setLoading(true) setLoading(true)
if (!data) { const newData = await getPoolSharesData(accountId, chainIds)
await fetchPoolSharesData() setData(newData)
return refetchPoolSharesData()
} }
for (let i = 0; i < data.length; i++) { init()
const did = web3.utils }, [accountId, chainIds, refetchPoolSharesData])
.toChecksumAddress(data[i].poolId.datatokenAddress)
.replace('0x', 'did:op:') useEffect(() => {
const ddo = await retrieveDDO(did, source.token) if (!data) return
const userLiquidity = calculateUserLiquidity(data[i])
assetList.push({ async function getShares() {
poolShare: data[i], try {
userLiquidity: userLiquidity, const newAssets = await getPoolSharesAssets(data)
networkId: ddo.chainId, if (JSON.stringify(assets) !== JSON.stringify(newAssets)) {
createTime: data[i].poolId.createTime setAssets(newAssets)
})
} }
const orderedAssets = assetList.sort(
(a, b) => b.createTime - a.createTime
)
setAssets(orderedAssets)
refetchPoolShares()
} catch (error) { } catch (error) {
console.error('Error fetching pool shares: ', error.message) console.error('Error fetching pool shares: ', error.message)
} finally { } finally {
setLoading(false) setLoading(false)
} }
} }
getShares() getShares()
}, [accountId, chainIds, data]) }, [accountId, chainIds, data, assets])
return accountId ? ( return accountId ? (
<Table <Table