From 7325e093ad8db1a0c87aa09f7d3a80a4103ddc8e Mon Sep 17 00:00:00 2001 From: Matthias Kretschmann Date: Fri, 20 Nov 2020 11:29:42 +0100 Subject: [PATCH] refactor transaction titles (#266) * refactor transaction titles * refactor * refactor * bump @oceanprotocol/lib * shorter getTitle * remove util duplicate * table tweaks --- package.json | 2 +- src/components/molecules/PoolTransactions.tsx | 91 ++++++++++++------- .../AssetActions/Pool/Transactions.module.css | 12 +++ 3 files changed, 69 insertions(+), 36 deletions(-) diff --git a/package.json b/package.json index e62dd090a..db82dd52c 100644 --- a/package.json +++ b/package.json @@ -24,7 +24,7 @@ "@coingecko/cryptoformat": "^0.4.2", "@loadable/component": "^5.14.1", "@oceanprotocol/art": "^3.0.0", - "@oceanprotocol/lib": "^0.9.16", + "@oceanprotocol/lib": "^0.9.17", "@oceanprotocol/list-datapartners": "^1.0.3", "@oceanprotocol/react": "^0.3.19", "@oceanprotocol/typographies": "^0.1.0", diff --git a/src/components/molecules/PoolTransactions.tsx b/src/components/molecules/PoolTransactions.tsx index 8f9648b66..da205b782 100644 --- a/src/components/molecules/PoolTransactions.tsx +++ b/src/components/molecules/PoolTransactions.tsx @@ -6,51 +6,73 @@ import Time from '../atoms/Time' import Table from '../atoms/Table' import AssetTitle from './AssetListTitle' import styles from './PoolTransactions.module.css' -import { formatCurrency } from '@coingecko/cryptoformat' import { useUserPreferences } from '../../providers/UserPreferences' +import { Ocean } from '@oceanprotocol/lib' +import { formatPrice } from '../atoms/Price/PriceUnit' -function formatNumber(number: number, locale: string) { - return formatCurrency(number, '', locale, true, { - significantFigures: 6 - }) +async function getSymbol( + ocean: Ocean, + tokenAddress: string, + oceanTokenAddress: string +) { + const symbol = + oceanTokenAddress === tokenAddress + ? 'OCEAN' + : await ocean.datatokens.getSymbol(tokenAddress) + + return symbol +} + +async function getTitle( + ocean: Ocean, + row: PoolTransaction, + locale: string, + oceanTokenAddress: string +) { + const addRemoveSymbol = await getSymbol( + ocean, + row.tokenIn || row.tokenOut, + oceanTokenAddress + ) + + const title = + row.type === 'join' + ? `Add ${formatPrice(row.tokenAmountIn, locale)} ${addRemoveSymbol}` + : row.type === 'exit' + ? `Remove ${formatPrice(row.tokenAmountOut, locale)} ${addRemoveSymbol}` + : `Swap ${formatPrice(row.tokenAmountIn, locale)} ${await getSymbol( + ocean, + row.tokenIn, + oceanTokenAddress + )} for ${formatPrice(row.tokenAmountOut, locale)} ${await getSymbol( + ocean, + row.tokenOut, + oceanTokenAddress + )}` + + return title } function Title({ row }: { row: PoolTransaction }) { - const { ocean, networkId } = useOcean() - const [dtSymbol, setDtSymbol] = useState() + const { ocean, networkId, config } = useOcean() + const [title, setTitle] = useState() const { locale } = useUserPreferences() - const symbol = dtSymbol || 'OCEAN' - const title = - row.type === 'join' - ? `Add ${formatNumber(Number(row.tokenAmountIn), locale)} ${symbol}` - : row.type === 'exit' - ? `Remove ${formatNumber(Number(row.tokenAmountOut), locale)} ${symbol}` - : `Swap ${formatNumber( - Number(row.tokenAmountIn), - locale - )} ${symbol} for ${formatNumber( - Number(row.tokenAmountOut), - locale - )} ${symbol}` - useEffect(() => { - if (!ocean) return + if (!ocean || !locale || !row || !config?.oceanTokenAddress) return - async function getSymbol() { - const symbol = await ocean.datatokens.getSymbol( - row.tokenIn || row.tokenOut - ) - setDtSymbol(symbol) + async function init() { + const title = await getTitle(ocean, row, locale, config.oceanTokenAddress) + setTitle(title) } - getSymbol() - }, [ocean, row]) + init() + }, [ocean, row, locale, config?.oceanTokenAddress]) - return ( + return title ? ( {title} - ) + ) : null } function getColumns(minimal?: boolean) { @@ -59,9 +81,7 @@ function getColumns(minimal?: boolean) { name: 'Title', selector: function getTitleRow(row: PoolTransaction) { return - }, - minWidth: '14rem', - grow: 1 + } }, { name: 'Data Set', @@ -82,7 +102,8 @@ function getColumns(minimal?: boolean) { isUnix /> ) - } + }, + maxWidth: '10rem' } ] } diff --git a/src/components/organisms/AssetActions/Pool/Transactions.module.css b/src/components/organisms/AssetActions/Pool/Transactions.module.css index a0ac646d1..a9e4e1eb9 100644 --- a/src/components/organisms/AssetActions/Pool/Transactions.module.css +++ b/src/components/organisms/AssetActions/Pool/Transactions.module.css @@ -43,3 +43,15 @@ .open .toggle svg { transform: rotate(180deg); } + +.transactions [class*='Table-module--table'] { + /* + react-data-table-component sets a default width: 100% + which often leads to unneccessary overflows. Following lines make + sure table always spans between edges of container, without any overflow + when enough space is available. But it also destroys overflow table on narrow + viewports. + */ + width: fit-content !important; + min-width: 100%; +}