From a3b7498a89576a5aac4c2cd5581d8ce4d457b718 Mon Sep 17 00:00:00 2001 From: shadab-taiko <108871478+shadab-taiko@users.noreply.github.com> Date: Fri, 14 Apr 2023 15:56:04 +0530 Subject: [PATCH] feat(bridge-ui): add transaction list pagination (#13586) Co-authored-by: Francisco Ramos --- packages/bridge-ui/src/App.svelte | 22 ++++- .../src/components/Pagination.svelte | 93 +++++++++++++++++++ .../Transactions/Transactions.svelte | 41 +++++++- packages/bridge-ui/src/domain/relayerApi.ts | 21 ++++- .../src/relayer-api/RelayerAPIService.ts | 21 ++++- packages/bridge-ui/src/store/relayerApi.ts | 9 +- 6 files changed, 194 insertions(+), 13 deletions(-) create mode 100644 packages/bridge-ui/src/components/Pagination.svelte diff --git a/packages/bridge-ui/src/App.svelte b/packages/bridge-ui/src/App.svelte index 52f1421aa5e..f420d4c672d 100644 --- a/packages/bridge-ui/src/App.svelte +++ b/packages/bridge-ui/src/App.svelte @@ -29,8 +29,16 @@ import { CustomTokenService } from './storage/CustomTokenService'; import { userTokens, tokenService } from './store/userToken'; import { RelayerAPIService } from './relayer-api/RelayerAPIService'; - import type { RelayerAPI } from './domain/relayerApi'; - import { relayerApi, relayerBlockInfoMap } from './store/relayerApi'; + import { + DEFAULT_PAGE, + MAX_PAGE_SIZE, + type RelayerAPI, + } from './domain/relayerApi'; + import { + paginationInfo, + relayerApi, + relayerBlockInfoMap, + } from './store/relayerApi'; import { chains, mainnetWagmiChain, taikoWagmiChain } from './chain/chains'; import { providers } from './provider/providers'; import { RELAYER_URL } from './constants/envVars'; @@ -91,9 +99,13 @@ if (store) { const userAddress = await store.getAddress(); - const apiTxs = await $relayerApi.getAllBridgeTransactionByAddress( - userAddress, - ); + const { txs: apiTxs, paginationInfo: info } = + await $relayerApi.getAllBridgeTransactionByAddress(userAddress, { + page: DEFAULT_PAGE, + size: MAX_PAGE_SIZE, + }); + + paginationInfo.set(info); const blockInfoMap = await $relayerApi.getBlockInfo(); relayerBlockInfoMap.set(blockInfoMap); diff --git a/packages/bridge-ui/src/components/Pagination.svelte b/packages/bridge-ui/src/components/Pagination.svelte new file mode 100644 index 00000000000..5a9e8f88d0e --- /dev/null +++ b/packages/bridge-ui/src/components/Pagination.svelte @@ -0,0 +1,93 @@ + + + + + diff --git a/packages/bridge-ui/src/components/Transactions/Transactions.svelte b/packages/bridge-ui/src/components/Transactions/Transactions.svelte index 730c1d2b236..dda608afda0 100644 --- a/packages/bridge-ui/src/components/Transactions/Transactions.svelte +++ b/packages/bridge-ui/src/components/Transactions/Transactions.svelte @@ -1,20 +1,56 @@
- {#if $transactions.length} + {#if transactionsToShow.length} @@ -26,7 +62,7 @@ - {#each $transactions as transaction (transaction.hash)} + {#each transactionsToShow as transaction (transaction.hash)} noticeModal.open(detail)} on:tooltipStatus={() => (showMessageStatusTooltip = true)} @@ -38,6 +74,7 @@ {/each}
+ {:else} No transactions {/if} diff --git a/packages/bridge-ui/src/domain/relayerApi.ts b/packages/bridge-ui/src/domain/relayerApi.ts index 8aa59975dc5..4abc5621b52 100644 --- a/packages/bridge-ui/src/domain/relayerApi.ts +++ b/packages/bridge-ui/src/domain/relayerApi.ts @@ -1,11 +1,25 @@ import type { Address, ChainID } from './chain'; import type { BridgeTransaction } from './transactions'; +export const MAX_PAGE_SIZE = 100; +export const DEFAULT_PAGE = 0; + +export type GetAllByAddressResponse = { + txs: BridgeTransaction[]; + paginationInfo: PaginationInfo; +}; + +export type PaginationParams = { + size: typeof MAX_PAGE_SIZE; + page: number; +}; + export interface RelayerAPI { getAllBridgeTransactionByAddress( address: string, + pagination: PaginationParams, chainID?: number, - ): Promise; + ): Promise; getBlockInfo(): Promise>; } @@ -71,3 +85,8 @@ export type APIResponse = { first: boolean; visible: number; }; + +export type PaginationInfo = Pick< + APIResponse, + 'page' | 'size' | 'max_page' | 'total_pages' | 'total' | 'last' | 'first' +>; diff --git a/packages/bridge-ui/src/relayer-api/RelayerAPIService.ts b/packages/bridge-ui/src/relayer-api/RelayerAPIService.ts index e09811633dd..6a49d683dfe 100644 --- a/packages/bridge-ui/src/relayer-api/RelayerAPIService.ts +++ b/packages/bridge-ui/src/relayer-api/RelayerAPIService.ts @@ -10,6 +10,9 @@ import type { APIRequestParams, APIResponse, APIResponseTransaction, + GetAllByAddressResponse, + PaginationInfo, + PaginationParams, RelayerAPI, RelayerBlockInfo, } from '../domain/relayerApi'; @@ -46,8 +49,9 @@ export class RelayerAPIService implements RelayerAPI { async getAllBridgeTransactionByAddress( address: string, + paginationParams: PaginationParams, chainID?: number, - ): Promise { + ): Promise { if (!address) { throw new Error('Address need to passed to fetch transactions'); } @@ -56,12 +60,23 @@ export class RelayerAPIService implements RelayerAPI { address, chainID, event: 'MessageSent', + ...paginationParams, }; const apiTxs: APIResponse = await this.getTransactionsFromAPI(params); + const paginationInfo: PaginationInfo = { + page: apiTxs.page, + size: apiTxs.size, + total: apiTxs.total, + total_pages: apiTxs.total_pages, + first: apiTxs.first, + last: apiTxs.last, + max_page: apiTxs.max_page, + }; + if (apiTxs?.items?.length === 0) { - return []; + return { txs: [], paginationInfo }; } apiTxs.items.map((t, i) => { @@ -193,7 +208,7 @@ export class RelayerAPIService implements RelayerAPI { bridgeTxs.reverse(); bridgeTxs.sort((tx) => (tx.status === MessageStatus.New ? -1 : 1)); - return bridgeTxs; + return { txs: bridgeTxs, paginationInfo }; } async getBlockInfo(): Promise> { diff --git a/packages/bridge-ui/src/store/relayerApi.ts b/packages/bridge-ui/src/store/relayerApi.ts index 79841d17a3b..d12cfd1bf4f 100644 --- a/packages/bridge-ui/src/store/relayerApi.ts +++ b/packages/bridge-ui/src/store/relayerApi.ts @@ -1,7 +1,12 @@ -import type { RelayerAPI, RelayerBlockInfo } from '../domain/relayerApi'; +import type { + PaginationInfo, + RelayerAPI, + RelayerBlockInfo, +} from '../domain/relayerApi'; import { writable } from 'svelte/store'; const relayerApi = writable(); const relayerBlockInfoMap = writable>(); +const paginationInfo = writable(); -export { relayerApi, relayerBlockInfoMap }; +export { relayerApi, relayerBlockInfoMap, paginationInfo };