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

CentrifugeApp: Portfolio transaction table #1605

Merged
merged 40 commits into from
Oct 30, 2023
Merged
Show file tree
Hide file tree
Changes from 5 commits
Commits
Show all changes
40 commits
Select commit Hold shift + click to select a range
f3cde6c
Update transaction table styles and data fetching
sophialittlejohn Sep 27, 2023
17eab72
Filter transaction types for short table
sophialittlejohn Sep 27, 2023
9e6e567
Update styles in tx history page
sophialittlejohn Sep 27, 2023
d9e3cf8
Addsort buttons to table and view all button
sophialittlejohn Sep 28, 2023
532062d
Add count and txTypes to cent-js
sophialittlejohn Sep 28, 2023
3dff2a0
Create new history page
sophialittlejohn Sep 29, 2023
f8ae576
Remove old file
sophialittlejohn Sep 29, 2023
2689edc
Merge branch 'main' into cent-app/portfolio-transaction-table
hieronx Oct 2, 2023
1b78717
Merge branch 'main' of github.com:centrifuge/apps into cent-app/portf…
sophialittlejohn Oct 10, 2023
e34d67c
Add pagination
sophialittlejohn Oct 10, 2023
26f28f1
Resolve unique key error
sophialittlejohn Oct 13, 2023
67900c2
Fetch currencies once per poolId
sophialittlejohn Oct 13, 2023
8d10135
Merge branch 'main' into cent-app/portfolio-transaction-table
sophialittlejohn Oct 13, 2023
87dd3e8
Add CSV export
sophialittlejohn Oct 13, 2023
b56b861
Hide download button in preview
sophialittlejohn Oct 13, 2023
058368a
Merge branch 'main' into cent-app/portfolio-transaction-table
sophialittlejohn Oct 16, 2023
cad7795
Fix logs
sophialittlejohn Oct 16, 2023
afebaf3
Merge branch 'cent-app/portfolio-transaction-table' of github.com:cen…
sophialittlejohn Oct 16, 2023
0adadef
Merge branch 'main' of github.com:centrifuge/apps into cent-app/portf…
sophialittlejohn Oct 20, 2023
35db8ff
Add more query keys
sophialittlejohn Oct 20, 2023
f445227
Add loading state and internal link
sophialittlejohn Oct 23, 2023
176bbd0
Improve load time
sophialittlejohn Oct 23, 2023
1ebce79
Add loop ids
sophialittlejohn Oct 23, 2023
e505fff
Merge branch 'main' of github.com:centrifuge/apps into cent-app/portf…
sophialittlejohn Oct 25, 2023
2bf06e4
Fix table rendering
sophialittlejohn Oct 25, 2023
0f16c50
Merge branch 'main' of github.com:centrifuge/apps into cent-app/portf…
sophialittlejohn Oct 27, 2023
96f5f36
Restructure files
sophialittlejohn Oct 27, 2023
fe1c47e
Add pagination and csv export to DataTable
sophialittlejohn Oct 27, 2023
fc56eb1
Use DataTable for transactions
sophialittlejohn Oct 27, 2023
84efc6b
Add title to tx table
sophialittlejohn Oct 27, 2023
d5e8ad1
Convert invested token table to new style
sophialittlejohn Oct 27, 2023
5791310
Adjust percision and table width
sophialittlejohn Oct 27, 2023
7ee615a
Fix border
sophialittlejohn Oct 27, 2023
91bd04b
Fix linting
sophialittlejohn Oct 27, 2023
c34aeaa
Fix pool list key
sophialittlejohn Oct 27, 2023
59fa110
Clean up
sophialittlejohn Oct 27, 2023
f78c808
Lint fix
sophialittlejohn Oct 27, 2023
076a915
refactor
onnovisser Oct 30, 2023
38f9ef2
cleanup
onnovisser Oct 30, 2023
f185db4
Merge commit 'b973b1de7c359182ad994c86fbac88a9eccf3a7a' into cent-app…
onnovisser Oct 30, 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
2 changes: 1 addition & 1 deletion centrifuge-app/.env-config/.env.development
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ REACT_APP_PINNING_API_URL=https://europe-central2-peak-vista-185616.cloudfunctio
REACT_APP_POOL_CREATION_TYPE=immediate
REACT_APP_RELAY_WSS_URL=wss://fullnode-relay.development.cntrfg.com
REACT_APP_SUBQUERY_URL=https://api.subquery.network/sq/centrifuge/pools-development
REACT_APP_SUBSCAN_URL=
REACT_APP_SUBSCAN_URL=https://centrifuge.subscan.io
REACT_APP_TINLAKE_NETWORK=goerli
REACT_APP_INFURA_KEY=bf808e7d3d924fbeb74672d9341d0550
REACT_APP_WHITELISTED_ACCOUNTS=
Expand Down
4 changes: 2 additions & 2 deletions centrifuge-app/src/components/PoolList.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -90,12 +90,12 @@ export function PoolList() {
? Array(6)
.fill(true)
.map((_, index) => (
<Box as="li" key={index}>
<Box as="li" key={`pool-list-loading-${index}`}>
<PoolCard isLoading={true} />
</Box>
))
: filteredPools.map((pool) => (
<PoolCardBox as="li" key={pool.poolId} status={pool.status}>
<PoolCardBox as="li" key={`pool-list-${pool.poolId}-${Math.random()}`} status={pool.status}>
sophialittlejohn marked this conversation as resolved.
Show resolved Hide resolved
<PoolCard {...pool} />
</PoolCardBox>
))}
Expand Down
4 changes: 2 additions & 2 deletions centrifuge-app/src/components/Portfolio/AssetAllocation.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ export function AssetAllocation({ address }: { address: string }) {
<AssetClassChart data={shares} currency="USD" total={total.toNumber()} />
<Shelf as="ul" alignSelf="stretch" alignItems="stretch" flex={1} gap={6}>
{shares.map((cell, i) => (
<>
<Box key={`asset-allocation-${cell.name}-${i}`}>
{i > 0 && <Box width="1px" backgroundColor="borderSecondary" />}
<LabelValueStack
label={
Expand All @@ -84,7 +84,7 @@ export function AssetAllocation({ address }: { address: string }) {
}
key={i}
/>
</>
</Box>
))}
</Shelf>
</Shelf>
Expand Down
30 changes: 19 additions & 11 deletions centrifuge-app/src/components/Portfolio/Transactions.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -20,15 +20,17 @@
Stack,
Text,
usePagination,
VisualButton,
} from '@centrifuge/fabric'
import * as React from 'react'
import { useRouteMatch } from 'react-router-dom'
import { Link, useRouteMatch } from 'react-router-dom'
import styled from 'styled-components'
import { formatDate } from '../../utils/date'
import { formatBalance } from '../../utils/formatting'
import { getCSVDownloadUrl } from '../../utils/getCSVDownloadUrl'
import { useAddress } from '../../utils/useAddress'
import { usePool, usePoolMetadata, usePools, useTransactionsByAddress } from '../../utils/usePools'
import { Spinner } from '../Spinner'
import { TransactionTypeChip } from './TransactionTypeChip'

export const TRANSACTION_CARD_COLUMNS = `150px 125px 200px 150px 1fr`
Expand All @@ -42,19 +44,21 @@
export function Transactions({ count, txTypes }: TransactionsProps) {
const { formatAddress } = useCentrifugeUtils()
const address = useAddress()
const transactions = useTransactionsByAddress(formatAddress(address || ''), count, txTypes)
const transactions = useTransactionsByAddress(formatAddress(address || ''))
const match = useRouteMatch('/history')
const [sortKey, setSortKey] = React.useState<'date' | 'amount'>('date')
const [sortOrder, setSortOrder] = React.useState<'asc' | 'desc'>('desc')
const pagination = usePagination({
data: transactions?.investorTransactions,
data: transactions?.investorTransactions || [],
pageSize: 10,
})
const pools = usePools()

const investorTransactions: TransactionListItemProps[] = React.useMemo(() => {
const txs =
transactions?.investorTransactions
.slice(0, count || transactions?.investorTransactions.length)
.filter((tx) => (txTypes ? txTypes?.includes(tx.type) : tx))
.map((tx) => {
return {
date: new Date(tx.timestamp).getTime(),
Expand All @@ -75,7 +79,7 @@
}
}) || []
return sortOrder === 'asc' ? txs.reverse() : txs
}, [sortKey, transactions, sortOrder, pagination])
}, [sortKey, transactions, sortOrder, txTypes, count])

const paginatedInvestorTransactions = React.useMemo(() => {
return investorTransactions.slice(
Expand All @@ -97,7 +101,7 @@
Amount: pool ? `"${formatBalance(entry.amount.toDecimal(), pool.currency.symbol)}"` : undefined,
}
})
}, [investorTransactions])

Check warning on line 104 in centrifuge-app/src/components/Portfolio/Transactions.tsx

View workflow job for this annotation

GitHub Actions / build-app

React Hook React.useMemo has a missing dependency: 'pools'. Either include it or remove the dependency array

return !!paginatedInvestorTransactions.length ? (
<PaginationContainer pagination={pagination}>
Expand Down Expand Up @@ -166,14 +170,16 @@
</Stack>
</Stack>
{match ? null : (
<Box>
<AnchorButton small variant="tertiary" href="history" icon={IconEye}>
View all
</AnchorButton>
</Box>
<Link to="/history">
<Box display="inline-block">
<VisualButton small variant="tertiary" icon={IconEye}>
View all
</VisualButton>
</Box>
</Link>
)}
<Shelf justifyContent="space-between">
{pagination.pageCount > 1 && (
{match && pagination.pageCount > 1 && (
<Shelf>
<Pagination />
</Shelf>
Expand All @@ -191,7 +197,9 @@
</Shelf>
</Stack>
</PaginationContainer>
) : null
) : (
<Spinner />
)
}

export type TransactionListItemProps = {
Expand Down
14 changes: 4 additions & 10 deletions centrifuge-app/src/utils/usePools.ts
Original file line number Diff line number Diff line change
@@ -1,10 +1,4 @@
import Centrifuge, {
BorrowerTransaction,
InvestorTransactionType,
Loan,
Pool,
PoolMetadata,
} from '@centrifuge/centrifuge-js'
import Centrifuge, { BorrowerTransaction, Loan, Pool, PoolMetadata } from '@centrifuge/centrifuge-js'
import { useCentrifugeConsts, useCentrifugeQuery, useWallet } from '@centrifuge/centrifuge-react'
import BN from 'bn.js'
import { useEffect, useMemo } from 'react'
Expand Down Expand Up @@ -58,10 +52,10 @@ export function useMonthlyPoolStates(poolId: string, from?: Date, to?: Date) {
return result
}

export function useTransactionsByAddress(address?: string, count?: number, txTypes?: InvestorTransactionType[]) {
export function useTransactionsByAddress(address?: string) {
const [result] = useCentrifugeQuery(
['txByAddress', count, address, txTypes],
(cent) => cent.pools.getTransactionsByAddress([address!, count, txTypes]),
['txByAddress', address],
(cent) => cent.pools.getTransactionsByAddress([address!]),
{
enabled: !!address,
}
Expand Down
21 changes: 9 additions & 12 deletions centrifuge-js/src/modules/pools.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2004,7 +2004,7 @@ export function getPoolsModule(inst: Centrifuge) {
}

function getTransactionsByAddress(args: [address: string, count?: number, txTypes?: InvestorTransactionType[]]) {
const [address, count, txTypes] = args
const [address] = args

const $query = inst.getSubqueryObservable<{
investorTransactions: { nodes: SubqueryInvestorTransaction[] }
Expand Down Expand Up @@ -2036,9 +2036,9 @@ export function getPoolsModule(inst: Centrifuge) {
switchMap((data) => {
const poolIds = new Set(data?.investorTransactions.nodes.map((e) => e.poolId)) ?? []
const $poolCurrencies = Array.from(poolIds).map((poolId) => getPoolCurrency([poolId]))
return combineLatest([$query, ...$poolCurrencies]).pipe(
map(([data, ...currencies]) => {
return data?.investorTransactions.nodes.map((tx) => {
return combineLatest($poolCurrencies).pipe(
map((currencies) => {
const txs = data?.investorTransactions.nodes.map((tx) => {
const currencyIndex = Array.from(poolIds).indexOf(tx.poolId)
const poolCurrency = currencies[currencyIndex]
return {
Expand All @@ -2049,15 +2049,12 @@ export function getPoolsModule(inst: Centrifuge) {
trancheId: tx.trancheId.split('-')[1],
}
})
return {
investorTransactions: txs || [],
}
})
)
}),
map((investorTransactions) => ({
investorTransactions:
investorTransactions
?.filter((tx) => (txTypes ? txTypes?.includes(tx.type) : tx))
.slice(0, count || investorTransactions.length) ?? [],
}))
})
)
}

Expand Down Expand Up @@ -2808,7 +2805,7 @@ export function getPoolsModule(inst: Centrifuge) {
const update = updateData.toPrimitive() as any
if (!update?.changes) return null
const { changes, submittedAt } = update

return {
changes: {
tranches: changes.tranches.noChange === null ? null : changes.tranches.newValue,
Expand Down
Loading