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

Add pnl analytics to balances table #143

Merged
merged 10 commits into from
Feb 8, 2024
Merged
Show file tree
Hide file tree
Changes from 9 commits
Commits
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
23 changes: 2 additions & 21 deletions src/components/homePage/AccountInfo.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,17 +3,14 @@ import { MutedDiv } from '../utils/MutedText'
import Section from '../utils/Section'
import { CopyAddress } from './address-views/utils'
import { LARGE_AVATAR_SIZE } from '../utils/Size.config'
import { toShortAddress, convertAddressToChainFormat } from '../utils/index'
import { toShortAddress } from '../utils/index'
import { DfMd } from '../utils/DfMd'
import { useMyExtensionAddresses } from '../providers/MyExtensionAccountsContext'
import { useResponsiveSize } from '../responsive'
import BaseAvatar from '../utils/DfAvatar'
import styles from './address-views/utils/index.module.sass'
import { LinkWithIcon } from '../table/utils'
import { resolveStatescanUrl } from '../table/links'
import { AddressQrModal } from '../qrs/QrModal'
import clsx from 'clsx'
import { useChainInfo } from '../../rtk/features/multiChainInfo/multiChainInfoHooks'
import { allAccountsAvatar } from './address-views/utils/index'
import { toGenericAccountId } from 'src/rtk/app/util'
import {
Expand Down Expand Up @@ -60,7 +57,6 @@ export const AccountInfo = (props: Props) => {
const { t } = useTranslation()

const accounts = useMyExtensionAddresses()
const chains = useChainInfo()

let { image: accountAvatar, about: accountDescription } = owner || {}

Expand All @@ -84,11 +80,6 @@ export const AccountInfo = (props: Props) => {

const genericAccountId = toGenericAccountId(address?.toString())

const ksmAddress = convertAddressToChainFormat(
address?.toString(),
chains?.kusama?.ss58Format
)

const addressView = (
<div
className={clsx(
Expand All @@ -109,21 +100,11 @@ export const AccountInfo = (props: Props) => {
<div className='d-flex align-items-center'>
{address && (
<AddressQrModal
className='grey-light'
className='GrayIcon'
address={address.toString()}
openFromUrl
/>
)}

{ksmAddress && (
<LinkWithIcon
link={resolveStatescanUrl(ksmAddress)}
className={clsx(styles.StatescanLink, 'grey-light')}
withCircle={false}
title={t('buttons.viewAddressOn', { website: 'Statescan.io' })}
icon='/images/statescan.svg'
/>
)}
</div>
</div>
)
Expand Down
4 changes: 2 additions & 2 deletions src/components/homePage/HomePageLayout.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import NtfLayout from '../ntf/NftsLayout'
import { Tabs } from 'antd'
import { useEffect, useMemo, useState } from 'react'
import styles from './Index.module.sass'
import BalancesTableNew from '../table/balancesTable'
import BalancesTable from '../table/balancesTable'
import { useSendEvent } from '../providers/AnalyticContext'
import { useRouter } from 'next/router'
import TxHistoryLayout from '../txHistory'
Expand Down Expand Up @@ -44,7 +44,7 @@ const HomePageLayout = ({ addresses }: OverviewSectionProps) => {
{
key: 'portfolio',
tab: 'Portfolio',
children: <BalancesTableNew addresses={addresses} />,
children: <BalancesTable addresses={addresses} />,
},
{
key: 'nfts',
Expand Down
8 changes: 5 additions & 3 deletions src/components/homePage/address-views/utils/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ type BalanceViewProps = {
defaultPostfix?: string
style?: CSSProperties
className?: string
decimalClassName?: string
}

export const BalanceView = ({
Expand All @@ -42,6 +43,7 @@ export const BalanceView = ({
defaultPostfix = '00',
className,
style,
decimalClassName
}: BalanceViewProps) => {
if (!value) return <>-</>

Expand Down Expand Up @@ -77,7 +79,7 @@ export const BalanceView = ({
{postfixValue && (
<>
.
<span className='DfBalanceDecimals'>
<span className={clsx('DfBalanceDecimals', decimalClassName)}>
{isPrefixInString ? postfixValue.slice(0, -1) : postfixValue}
</span>
</>
Expand Down Expand Up @@ -112,7 +114,7 @@ export const CopyAddress = ({

return (
<Copy
className={clsx('DfGreyLink', {
className={clsx('GrayText', {
[styles.Copy]: !iconVisibility,
}, className)}
text={address.toString()}
Expand All @@ -126,7 +128,7 @@ export const CopyAddress = ({
})}
>
{children}
<CopyOutlined className='ml-1 grey-light DfGreyLink' />
<CopyOutlined className='ml-1 GrayIcon' />
</div>
</Tooltip>
</Copy>
Expand Down
2 changes: 1 addition & 1 deletion src/components/qrs/QrModal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -94,7 +94,7 @@ export const AddressQrModal = ({ className, modalClassName, ...props }: Omit<QrM

const QrButton = (props: ButtonProps) => (
<Tooltip title={t('tooltip.showQR')}>
<HiOutlineQrCode className={clsx('DfGreyLink', className)} style={{ transform: 'scale(1.15)' }} {...(props as any)} />
<HiOutlineQrCode className={clsx('GrayIcon', className)} style={{ transform: 'scale(1.15)' }} {...(props as any)} />
</Tooltip>
)

Expand Down
17 changes: 16 additions & 1 deletion src/components/table/Table.module.sass
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,20 @@ $zero_margin: 0
.DfCol
width: 100%

.RowTitle
font-size: $font_normal

.RowTitleBold
font-weight: 600

@media ( max-width: $max_mobile_width )
.RowTitle
font-size: 15px

.RowValue
display: flex
flex-direction: column

.Card
min-height: 5rem
border-radius: $border_radius_normal
Expand Down Expand Up @@ -322,6 +336,7 @@ $zero_margin: 0
border-bottom: 1px solid #f0f0f0

.NonTokenImage
width: 24px
max-width: 24px
width: 100%
height: 24px
font-size: $font_small
28 changes: 13 additions & 15 deletions src/components/table/balancesTable/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ import clsx from 'clsx'
import styles from '../Table.module.sass'
import {
BALANCE_SHOW_ZERO_BALANCES,
BALANCE_TABLE_VARIANT,
BALANCE_TABLE_VIEW,
BalancePart,
} from '../utils'
Expand All @@ -13,9 +12,6 @@ import {
} from '../customTable/TableContext'
import { useTranslation } from 'react-i18next'
import { useIsMyConnectedAddress } from 'src/components/providers/MyExtensionAccountsContext'
import { useState } from 'react'
import { BalanceVariant } from './types'
import store from 'store'
import { useGetTableData } from './utils/useGetTableData'
import ActionPannel from './utils/ActionPannel'
import TransferModal from 'src/components/transfer/TransferModal'
Expand All @@ -30,18 +26,20 @@ type BalancesTableInnerProps = BalancesTableProps & {
storeTableView: string
}

const BalancesTableNewInner = (props: BalancesTableInnerProps) => {
const BalancesTableInner = (props: BalancesTableInnerProps) => {
const { storeShowZeroBalance, storeTableView, addresses } = props
const isMyAddress = useIsMyConnectedAddress(addresses?.[0])
const tableVariantFromStore = store.get(BALANCE_TABLE_VARIANT)
const { tableView, showZeroBalances } = useTableContext()

const [ balancesVariant, setBalancesVariant ] = useState<BalanceVariant>(
tableVariantFromStore || 'chains'
)
const { tableView, showZeroBalances, balancesVariant, setBalancesVariant } =
useTableContext()

const { loading, balancesLoading, data, transferModalState, transferModalDispatch } =
useGetTableData(addresses, balancesVariant)
const {
loading,
balancesLoading,
data,
transferModalState,
transferModalDispatch,
} = useGetTableData(addresses, balancesVariant)

const { t } = useTranslation()

Expand Down Expand Up @@ -78,7 +76,7 @@ const BalancesTableNewInner = (props: BalancesTableInnerProps) => {
)
}

const BalancesTableNew = (props: BalancesTableProps) => {
const BalancesTable = (props: BalancesTableProps) => {
const storeProps = {
storeShowZeroBalance: BALANCE_SHOW_ZERO_BALANCES,
storeTableView: BALANCE_TABLE_VIEW,
Expand All @@ -88,9 +86,9 @@ const BalancesTableNew = (props: BalancesTableProps) => {
<TableContextWrapper {...storeProps}>
<PricesWarning />

<BalancesTableNewInner {...storeProps} {...props} />
<BalancesTableInner {...storeProps} {...props} />
</TableContextWrapper>
)
}

export default BalancesTableNew
export default BalancesTable
Loading