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

TW-1360: [EVM] Home page design #1136

Merged
merged 149 commits into from
May 16, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
149 commits
Select commit Hold shift + click to select a range
556c12d
loadChainId() uses FastRpcClient cache
alex-tsx Mar 10, 2024
4b48701
TW-1345: Seed derivation for EVM. Refactor. + useTezosNetwork()
alex-tsx Mar 11, 2024
a07f96d
TW-1345: Seed derivation for EVM. Refactor. const { rpcUrl } = useTez…
alex-tsx Mar 11, 2024
762f939
TW-1345: Seed derivation for EVM. Refactor. + useTezosAccountAddress()
alex-tsx Mar 11, 2024
eb8513d
TW-1345: Seed derivation for EVM. Refactor. WIP: + useTezosAccount()
alex-tsx Mar 11, 2024
7dd7da6
TW-1345: Seed derivation for EVM. Refactor. WIP: + useTezosRelevantAc…
alex-tsx Mar 12, 2024
1a6f9f0
TW-1345: Seed derivation for EVM. Refactor. WIP: TempleAccount -> Sto…
alex-tsx Mar 12, 2024
6ab8d97
TW-1345: Seed derivation for EVM. Refactor. useTezosAccount()
alex-tsx Mar 12, 2024
ae3c7b2
TW-1345: Seed derivation for EVM. Refactor useChainId()
alex-tsx Mar 12, 2024
0244d5c
TW-1345: Seed derivation for EVM. Refactor. loadTezosChainId()
alex-tsx Mar 13, 2024
de25c7f
TW-1345: Seed derivation for EVM. Refactor. -- NewBlockTriggersProvid…
alex-tsx Mar 13, 2024
00bbd8e
TW-1345: Seed derivation for EVM. Refactor. + useOnTezosBlock()
alex-tsx Mar 13, 2024
a2437f1
TW-1345: Seed derivation for EVM. Refactor. TempleNetwork -> StoredNe…
alex-tsx Mar 13, 2024
b61e244
TW-1345: Seed derivation for EVM. Refactor. temple/hooks -> temple/front
alex-tsx Mar 13, 2024
f69c6e6
TW-1345: Seed derivation for EVM. Refactor. + temple/front/tzdns
alex-tsx Mar 13, 2024
a73a184
Merge branch 'development-2' into TW-1345-derivation-for-evm
alex-tsx Mar 13, 2024
85e6ad0
TW-1345: Seed derivation for EVM. Fix unit tests
alex-tsx Mar 14, 2024
f666b20
TW-1345: Seed derivation for EVM. WIP: + StoredHDAccount.evmAddress
alex-tsx Mar 15, 2024
8310e34
TW-1345: Seed derivation for EVM. WIP: Refactor
alex-tsx Mar 15, 2024
334ceea
Merge branch 'development-2' into TW-1345-derivation-for-evm
alex-tsx Mar 15, 2024
87a4448
TW-1345: Seed derivation for EVM. WIP: Refactor
alex-tsx Mar 15, 2024
3c1ea30
TW-1345: Seed derivation for EVM. WIP: Refactor
alex-tsx Mar 15, 2024
15b3a17
TW-1345: Seed derivation for EVM. Fix unit tests
alex-tsx Mar 15, 2024
7eeaeb8
TW-1345: Seed derivation for EVM. WIP: + StoredWatchOnlyAccount.chain
alex-tsx Mar 15, 2024
a4aba6d
TW-1345: Seed derivation for EVM. WIP: Watch-only accounts. + useTezo…
alex-tsx Mar 18, 2024
dd14f48
TW-1345: Seed derivation for EVM. WIP: Watch-only accounts. ++ useTez…
alex-tsx Mar 18, 2024
a41e1a8
TW-1345: Seed derivation for EVM. WIP: Watch-only accounts. +++ useTe…
alex-tsx Mar 18, 2024
b186ca3
TW-1345: Seed derivation for EVM. WIP: Watch-only accounts. useTezosA…
alex-tsx Mar 18, 2024
485cf82
TW-1345: Seed derivation for EVM. Refactor
alex-tsx Mar 18, 2024
9f9d981
TW-1345: Seed derivation for EVM. Watch-only accounts. + Importing
alex-tsx Mar 18, 2024
45d162a
TW-1345: Seed derivation for EVM. 'Receive' page. + EVM address
alex-tsx Mar 19, 2024
c165c49
TW-1345: Seed derivation for EVM. + StoredImportedAccount.chain
alex-tsx Mar 19, 2024
1fce1e4
TW-1345: Seed derivation for EVM. <MainBanner>. + Gas balance of EVM-…
alex-tsx Mar 19, 2024
d1e9ed8
TW-1345: Seed derivation for EVM. Fix derivation: 'accountIndex' -> '…
alex-tsx Mar 20, 2024
0beec9c
TW-1345: Seed derivation for EVM. Fix migration: + Saving pub(priv)Keys
alex-tsx Mar 20, 2024
49cfa35
TW-1345: Seed derivation for EVM. Migration refactor
alex-tsx Mar 20, 2024
e92f215
TW-1345: Seed derivation for EVM. Migration refactor
alex-tsx Mar 20, 2024
18e538c
TW-1345: Seed derivation for EVM. --publicKeyHash. WIP
alex-tsx Mar 21, 2024
9934583
TW-1345: Seed derivation for EVM. --publicKeyHash. WIP. Delegate page
alex-tsx Mar 21, 2024
b62b12c
TW-1345: Seed derivation for EVM. --publicKeyHash. WIP. Confirm windo…
alex-tsx Mar 21, 2024
2243ce9
TW-1345: Seed derivation for EVM. --publicKeyHash. WIP. Fix searchAnd…
alex-tsx Mar 21, 2024
f09ba47
TW-1345: Seed derivation for EVM. --publicKeyHash. WIP. Vault. New ac…
alex-tsx Mar 22, 2024
e85ff11
TW-1345: Seed derivation for EVM. --publicKeyHash. WIP. Pages 'Intern…
alex-tsx Mar 22, 2024
1865c68
TW-1345: Seed derivation for EVM. --publicKeyHash. WIP. useFilteredCo…
alex-tsx Mar 22, 2024
500cb4c
TW-1345: Seed derivation for EVM. Fix Reveal Private Key feature
alex-tsx Mar 22, 2024
1bff7d8
TW-1345: Seed derivation for EVM. Fix Reveal Secrets pages
alex-tsx Mar 23, 2024
9b7a8aa
TW-1345: Seed derivation for EVM. Fix listing EVM watch-only accounts…
alex-tsx Mar 23, 2024
ce72d38
TW-1345: Seed derivation for EVM. Fix connected account in Confirm Page
alex-tsx Mar 23, 2024
a7dd7fd
TW-1345: Seed derivation for EVM. --publicKeyHash. WIP. Fix ADs viewe…
alex-tsx Mar 24, 2024
cc16592
TW-1345: Seed derivation for EVM. --publicKeyHash. WIP. Reduced useTe…
alex-tsx Mar 24, 2024
09bda74
TW-1345: Seed derivation for EVM. Fix some translations
alex-tsx Mar 25, 2024
fe7b860
TW-1345: Seed derivation for EVM. --publicKeyHash. + useTezosWithSign…
alex-tsx Mar 25, 2024
a723b1c
TW-1345: Seed derivation for EVM. Refactor. Renaming
alex-tsx Mar 25, 2024
9a31f65
TW-1345: Seed derivation for EVM. Refactor. Moved under
alex-tsx Mar 25, 2024
99bd3c8
TW-1345: Seed derivation for EVM. Tune unit tests
alex-tsx Mar 25, 2024
0555824
TW-1345: Seed derivation for EVM. Clean-up
alex-tsx Mar 26, 2024
f1df2ee
Merge branch 'development-2' into TW-1345-derivation-for-evm
alex-tsx Mar 26, 2024
a1196b2
TW-1345: Seed derivation for EVM. GitHub Actions. + Code quality chec…
alex-tsx Mar 26, 2024
690b33e
TW-1345: Seed derivation for EVM. Fix code quality check
alex-tsx Mar 26, 2024
7ed4dab
TW-1413: EVM Networks. Refactor
alex-tsx Mar 26, 2024
37c8dd6
TW-1413: EVM Networks. Refactor
alex-tsx Mar 28, 2024
c0bdbe9
TW-1413: EVM Networks. MIGRATIONS. Tezos networks
alex-tsx Mar 28, 2024
4aa4f58
TW-1413: EVM Networks. + Dropdown Select
alex-tsx Mar 28, 2024
e82485d
TW-1413: EVM Networks. Settings. + EVM Networks
alex-tsx Mar 29, 2024
31ad8e9
Merge branch 'development-2' into TW-1413-evm-networks
alex-tsx Apr 1, 2024
6d034d8
Merge branch 'TW-1343-epic-evm-arch-prep' into TW-1413-evm-networks
alex-tsx Apr 1, 2024
9fdfe45
TW-1413: EVM Networks. + getReadOnlyEvm()
alex-tsx Apr 1, 2024
69c6c80
TW-1413: EVM Networks. + StoredTezosNetwork.chainId. -- 'DailyNet', '…
alex-tsx Apr 1, 2024
60c5667
TW-1413: EVM Networks. + NetworkBase.testnet?: boolean
alex-tsx Apr 1, 2024
cf02ca9
TW-1413: EVM Networks. Refactor + useChainIDsCheck()
alex-tsx Apr 2, 2024
83b9170
TW-1413: EVM Networks. Fix <NetworkButton> analytics props
alex-tsx Apr 3, 2024
28187f2
TW-1413: EVM Networks. WIP: AddAsset page.
alex-tsx Apr 3, 2024
0d2a24d
TW-1413: EVM Networks. -- isTezosNetwork()
alex-tsx Apr 3, 2024
901ca79
TW-1413: EVM Networks. WIP: -- useTezosNetwork(). -- useTezosWithSign…
alex-tsx Apr 3, 2024
b4b9193
TW-1413: EVM Networks. WIP: -- useTezosNetwork()
alex-tsx Apr 4, 2024
c2e69f3
TW-1413: EVM Networks. WIP: -- isTezosNetwork(). + <ChainSelector>
alex-tsx Apr 5, 2024
90650e1
TW-1413: EVM Networks. WIP: -- isTezosNetwork(). useBalance(..., netw…
alex-tsx Apr 8, 2024
c65f200
TW-1413: EVM Networks. -- useTezosNetwork(). In TZDNS hooks
alex-tsx Apr 8, 2024
12b2653
TW-1413: EVM Networks. -- useTezosNetwork(). Refactor
alex-tsx Apr 8, 2024
fed9bdc
TW-1413: EVM Networks. WIP: -- useTezosNetwork(). -- useGas()
alex-tsx Apr 9, 2024
0709cdc
TW-1413: EVM Networks. WIP: -- useTezosNetwork(). In <InFiat>
alex-tsx Apr 9, 2024
a4e7de1
TW-1413: EVM Networks. WIP: -- useTezosNetwork(). In CustomTezosChain…
alex-tsx Apr 9, 2024
8773791
TW-1413: EVM Networks. WIP: -- useTezosNetwork(). In Block Explorers
alex-tsx Apr 10, 2024
a1959e4
TW-1413: EVM Networks. WIP: -- useTezosNetwork(). In InternalConfirma…
alex-tsx Apr 10, 2024
2eb0b90
TW-1413: EVM Networks. WIP: -- useTezosNetwork(). In some root hooks
alex-tsx Apr 11, 2024
98ccf6e
TW-1413: EVM Networks. WIP: -- useTezosNetwork(). In useMetadataLoadi…
alex-tsx Apr 12, 2024
e502e6d
TW-1413: EVM Networks. WIP: -- useTezosNetwork(). In useAssetsLoading()
alex-tsx Apr 14, 2024
350e21b
TW-1413: EVM Networks. WIP: -- useTezosNetwork(). WIP: In useBalances…
alex-tsx Apr 15, 2024
aee8c4e
TW-1413: EVM Networks. WIP: -- useTezosNetwork(). WIP: In useBalances…
alex-tsx Apr 15, 2024
bb801d4
TW-1413: EVM Networks. WIP: -- useTezosNetwork(). WIP: <WithDataLoadi…
alex-tsx Apr 16, 2024
533d9f5
TW-1413: EVM Networks. WIP: -- useTezosNetwork(). WIP: <AppBalancesLo…
alex-tsx Apr 16, 2024
2195e8d
TW-1413: EVM Networks. WIP: -- useTezosNetwork(). WIP: <AppBalancesLo…
alex-tsx Apr 16, 2024
5e92cef
TW-1413: EVM Networks. Refactor
alex-tsx Apr 16, 2024
49b23c0
Merge branch 'TW-1343-epic-evm-arch-prep' into TW-1413-evm-networks
alex-tsx Apr 16, 2024
69672c8
TW-1413: EVM Networks. Refactor. enum TempleChainName -> TempleChainKind
alex-tsx Apr 16, 2024
fcf25a1
TW-1413: EVM Networks. Refactor. -- loadAccountTokensActions & loadAc…
alex-tsx Apr 16, 2024
242506c
TW-1413: EVM Networks. Refactor. useTempleReady()
alex-tsx Apr 16, 2024
cf3e165
TW-1413: EVM Networks. <AppRootHooks> fix running-out loading cycles
alex-tsx Apr 17, 2024
dd2216c
TW-1413: EVM Networks. Fix build. 'babel-loader' -> 'ts-loader'
alex-tsx Apr 17, 2024
7cdbfb2
TW-1413: EVM Networks. Build. Restrict React from BG script
alex-tsx Apr 18, 2024
d7d6d18
TW-1413: EVM Networks. Settings page
alex-tsx Apr 18, 2024
be8c60f
TW-1413: EVM Networks. -- TODO.md
alex-tsx Apr 18, 2024
bfcfad7
TW-1413: EVM Networks. Fix pipeline. -- 'yarn ts:e2e'
alex-tsx Apr 18, 2024
2e90fe8
TW-1413: EVM Networks. Fix useEnabledChains()
alex-tsx Apr 18, 2024
a62347f
TW-1413: EVM Networks. Refactor
alex-tsx Apr 18, 2024
220e25a
Merge branch 'TW-1343-epic-evm-arch-prep' into TW-1413-evm-networks
alex-tsx Apr 18, 2024
2045662
TW-1413: EVM Networks. Settings. Networs. + Chain toggle
alex-tsx Apr 19, 2024
1fc7ced
TW-1360: EVM Design. Home page. WIP
alex-tsx Apr 24, 2024
6b3f304
Merge branch 'TW-1343-epic-evm-arch-prep' into TW-1360-evm-home-page-…
alex-tsx Apr 24, 2024
a707c7e
TW-1360: EVM Design. Home page. WIP. Account addresses + copy
alex-tsx Apr 24, 2024
a6164c8
TW-1360: EVM Design. Home page. WIP. Menu dropdown
alex-tsx Apr 25, 2024
a2a0122
TW-1360: EVM Design. Home page. WIP. + Toaster
alex-tsx Apr 28, 2024
36821d3
TW-1360: EVM Design. Home page. WIP. Fix icons sizing. + <IconBase>
alex-tsx Apr 28, 2024
0de1460
TW-1360: EVM Design. Home page. WIP. Assets Search field
alex-tsx Apr 29, 2024
3b853b2
TW-1360: EVM Design. Home page. WIP. TailwindCSS v3
alex-tsx Apr 29, 2024
7ed81a8
TW-1360: EVM Design. Home page. WIP. Menu drop-down. Test Mode toggle…
alex-tsx May 1, 2024
dbcc479
TW-1360: EVM Design. Home page. WIP. Menu drop-down. + 'Notifications…
alex-tsx May 1, 2024
e2d7145
TW-1360: EVM Design. Home page. WIP. + <CaptionAlert>
alex-tsx May 1, 2024
12355eb
TW-1360: EVM Design. Home page. WIP. Content padding
alex-tsx May 3, 2024
0d7fdf9
Merge branch 'TW-1343-epic-evm-arch-prep' into TW-1360-evm-home-page-…
alex-tsx May 3, 2024
d8edf04
TW-1360: EVM Design. Home page. WIP. Rename 'Temple - Tezos & EVM Wal…
alex-tsx May 3, 2024
53ffafe
TW-1360: EVM Design. Home page. WIP. Restored <AccountsDropdown>
alex-tsx May 3, 2024
34c08da
TW-1360: EVM Design. Home page. WIP. + Icons naming convention
alex-tsx May 3, 2024
9233a22
TW-1360: EVM Design. Home page. WIP. Fix icons scaling
alex-tsx May 3, 2024
2bb7fd0
TW-1360: EVM Design. Home page. WIP. ++ Icons scaling logic
alex-tsx May 3, 2024
619f10f
TW-1360: EVM Design. Home page. WIP. -- Unused icons. + CheckUnusedIm…
alex-tsx May 6, 2024
d67bec7
TW-1360: EVM Design. Home page. WIP. ++ WebPack
alex-tsx May 6, 2024
6ec9eda
TW-1360: EVM Design. Home page. WIP. + <AccountsModal>. + Rubik font …
alex-tsx May 7, 2024
518f427
TW-1360: EVM Design. Home page. WIP. + Portal Events Leak Guard
alex-tsx May 8, 2024
93d67e2
TW-1360: EVM Design. Home page. -- AccountsDropdown
alex-tsx May 8, 2024
063357a
TW-1360: EVM Design. Home page. Moved 'History' button
alex-tsx May 8, 2024
5b6065a
TW-1360: EVM Design. Home page. Layouts
alex-tsx May 9, 2024
9f1e750
TW-1360: EVM Design. Home page. Text Fonts
alex-tsx May 10, 2024
8efd466
TW-1360: EVM Design. Home page. + <SuspenseContainer>
alex-tsx May 10, 2024
1e59175
TW-1360: EVM Design. Home page. Fix scroll-to collectibles tab smooth…
alex-tsx May 11, 2024
4c85c32
TW-1360: EVM Design. Home page. + <TotalEquity>
alex-tsx May 13, 2024
0a183bf
TW-1360: EVM Design. Home page. Clean-up
alex-tsx May 13, 2024
74d83e5
TW-1360: EVM Design. Home page. Icons moved
alex-tsx May 13, 2024
fc61ff9
TW-1360: EVM Design. Home page. Icons moved
alex-tsx May 13, 2024
95d76b6
TW-1360: EVM Design. Home page. + <NetworkLogoBase>
alex-tsx May 13, 2024
99e727a
TW-1360: EVM Design. Home page. + <StyledButton>
alex-tsx May 13, 2024
4acd9d6
TW-1360: EVM Design. Home page. Fix PageModal scrolling
alex-tsx May 13, 2024
d8c9bc0
TW-1360: EVM Design. Home page. Fix Unlock screen layout
alex-tsx May 13, 2024
c8dacaa
TW-1360: EVM Design. Home page. Fix PageModal inset in popup
alex-tsx May 14, 2024
f6c0321
TW-1360: EVM Design. Home page. Custom App Scroll
alex-tsx May 14, 2024
b30f879
TW-1360: EVM Design. Home page. Refactor
alex-tsx May 14, 2024
2dc7d87
TW-1360: EVM Design. Home page. Refactor
alex-tsx May 14, 2024
ce75246
TW-1360: EVM Design. Home page. Fix Onboarding overlay title
alex-tsx May 14, 2024
edc7ddb
TW-1360: EVM Design. Home page. Popup window size + refactor
alex-tsx May 16, 2024
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
Prev Previous commit
Next Next commit
TW-1360: EVM Design. Home page. + <TotalEquity>
  • Loading branch information
alex-tsx committed May 13, 2024
commit 4c85c32d6ffe9ea344a7fbb0fc509d5c9c292ee5
2 changes: 1 addition & 1 deletion src/app/atoms/AccountName.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ export const AccountName = memo<Props>(({ account, searchValue, smaller }) => {
<ActionsDropdownPopup
title={() => 'Select Address to copy'}
keshan3262 marked this conversation as resolved.
Show resolved Hide resolved
opened={props.opened}
lowered={!smaller}
lowering={smaller ? 1 : 3}
style={{ minWidth: 173 }}
>
{accountTezosAddress ? (
Expand Down
19 changes: 9 additions & 10 deletions src/app/atoms/ActionsDropdown.tsx
Original file line number Diff line number Diff line change
@@ -1,25 +1,24 @@
import React, { FC, PropsWithChildren, CSSProperties } from 'react';

import clsx from 'clsx';

import DropdownWrapper from './DropdownWrapper';

interface Props {
title: () => string;
opened: boolean;
lowered?: boolean;
lowering?: 1 | 2 | 3;
style?: CSSProperties;
}

export const ActionsDropdownPopup: FC<PropsWithChildren<Props>> = ({ title, opened, lowered, style, children }) => {
export const ActionsDropdownPopup: FC<PropsWithChildren<Props>> = ({
title,
opened,
lowering = 1,
style,
children
}) => {
//
return (
<DropdownWrapper
opened={opened}
design="day"
className={clsx('p-2 flex flex-col', lowered ? 'mt-3' : 'mt-1')}
style={style}
>
<DropdownWrapper opened={opened} design="day" className={`p-2 flex flex-col mt-${lowering}`} style={style}>
<div className="py-2.5 px-2 text-font-small-bold text-grey-1">{title()}</div>

{children}
Expand Down
140 changes: 140 additions & 0 deletions src/app/atoms/TotalEquity.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,140 @@
import React, { memo, useMemo } from 'react';

import BigNumber from 'bignumber.js';

import { useTotalBalance } from 'app/hooks/use-total-balance';
import { useSelector } from 'app/store';
import { TEZ_TOKEN_SLUG } from 'lib/assets';
import { useTezosAssetBalance } from 'lib/balances';
import { useFiatCurrency, useFiatToUsdRate } from 'lib/fiat-currency';
import { getTezosGasMetadata } from 'lib/metadata';
import { useTypedSWR } from 'lib/swr';
import { atomsToTokens } from 'lib/temple/helpers';
import { TEZOS_MAINNET_CHAIN_ID, type StoredAccount } from 'lib/temple/types';
import { isTruthy } from 'lib/utils';
import { ZERO } from 'lib/utils/numbers';
import { getAccountAddressForTezos, getAccountAddressForEvm } from 'temple/accounts';
import { getReadOnlyEvm } from 'temple/evm';
import { UNDER_DEVELOPMENT_MSG } from 'temple/evm/under_dev_msg';
import { useEthereumMainnetChain, useTezosMainnetChain } from 'temple/front';

import Money from './Money';

export type EquityCurrency = 'tez' | 'eth' | 'btc' | 'fiat';

interface Props {
account: StoredAccount;
currency: EquityCurrency;
}

export const TotalEquity = memo<Props>(({ account, currency }) => {
const tezosPkh = getAccountAddressForTezos(account);

if (tezosPkh) return <TotalEquityForTezosOnly accountPkh={tezosPkh} targetCurrency={currency} />;

const evmAddress = getAccountAddressForEvm(account);

if (evmAddress) return <TotalEquityForEvmOnly address={evmAddress} targetCurrency={currency} />;

// const totalTezosBalanceInDollar = useMemo(() => {
// if (!tezosPkh) return 0;
// }, [tezosPkh]);

return null;
});

const TotalEquityForTezosOnly = memo<{ accountPkh: string; targetCurrency: EquityCurrency }>(
({ accountPkh, targetCurrency }) => {
const totalTezosBalanceInDollar = useTotalBalance(accountPkh, TEZOS_MAINNET_CHAIN_ID);

if (targetCurrency === 'fiat') return <TotalEquityForTezosOnlyInFiat amountInDollar={totalTezosBalanceInDollar} />;

if (targetCurrency === 'tez')
return <TotalEquityForTezosOnlyInGas accountPkh={accountPkh} amountInDollar={totalTezosBalanceInDollar} />;

return <span>{UNDER_DEVELOPMENT_MSG}</span>;
}
);

const TotalEquityForTezosOnlyInFiat = memo<{ amountInDollar: string }>(({ amountInDollar }) => {
const {
selectedFiatCurrency: { symbol: fiatSymbol }
} = useFiatCurrency();

const fiatToUsdRate = useFiatToUsdRate();

const amountInFiat = useMemo(
() => (isTruthy(fiatToUsdRate) ? new BigNumber(amountInDollar).times(fiatToUsdRate) : ZERO),
[amountInDollar, fiatToUsdRate]
);

return (
<>
{/* <span className="mr-1">β‰ˆ</span> */}
alex-tsx marked this conversation as resolved.
Show resolved Hide resolved
<Money smallFractionFont={false} fiat>
{amountInFiat}
</Money>
<span style={SYMBOL_STYLE}>{fiatSymbol}</span>
</>
);
});

export const TotalEquityForTezosOnlyInGas = memo<{ accountPkh: string; amountInDollar: string }>(
({ amountInDollar, accountPkh }) => {
const network = useTezosMainnetChain();
const { symbol: gasTokenSymbol } = getTezosGasMetadata(TEZOS_MAINNET_CHAIN_ID);

//

const tezosToUsdRate = useSelector(state => state.currency.usdToTokenRates.data[TEZ_TOKEN_SLUG]);
const { value: gasBalance } = useTezosAssetBalance(TEZ_TOKEN_SLUG, accountPkh, network);

const amountInGas = useMemo(() => {
const amountInDollarBN = new BigNumber(amountInDollar);

const { decimals } = getTezosGasMetadata(network.chainId);

return amountInDollarBN.isZero() || !isTruthy(tezosToUsdRate)
? gasBalance
: amountInDollarBN.dividedBy(tezosToUsdRate).decimalPlaces(decimals);
}, [gasBalance, tezosToUsdRate, amountInDollar, network.chainId]);

return (
<>
<Money smallFractionFont={false}>{amountInGas || ZERO}</Money>
<span style={SYMBOL_STYLE}>{gasTokenSymbol}</span>
</>
);
}
);

const TotalEquityForEvmOnly = memo<{ address: HexString; targetCurrency: EquityCurrency }>(
({ address, targetCurrency }) => {
const mainnetChain = useEthereumMainnetChain();
const currency = mainnetChain.currency;

const viemClient = getReadOnlyEvm(mainnetChain.rpcBaseURL);

const { data, isLoading } = useTypedSWR(['evm-gas-balance', address, mainnetChain.rpcBaseURL], () =>
viemClient.getBalance({ address })
);

const balanceStr = useMemo(
() => (data ? atomsToTokens(String(data), currency.decimals).toFixed(6) : '0'),
[data, currency.decimals]
);

if (targetCurrency !== 'eth') return <span>{UNDER_DEVELOPMENT_MSG}</span>;

if (isLoading) return <span>Loading...</span>;

return (
<>
<Money smallFractionFont={false}>{balanceStr}</Money>
<span style={SYMBOL_STYLE}>{currency.symbol}</span>
</>
);
}
);

const SYMBOL_STYLE = { marginLeft: `${4 / 24}em` };
keshan3262 marked this conversation as resolved.
Show resolved Hide resolved
6 changes: 6 additions & 0 deletions src/app/icons/compact_down.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
15 changes: 4 additions & 11 deletions src/app/pages/AccountSettings/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,23 +4,20 @@ import clsx from 'clsx';

import { Button, Checkbox, Identicon } from 'app/atoms';
import CopyButton from 'app/atoms/CopyButton';
import { TotalEquity } from 'app/atoms/TotalEquity';
import { useAllAccountsReactiveOnRemoval } from 'app/hooks/use-all-accounts-reactive';
import { useTotalBalance } from 'app/hooks/use-total-balance';
import { ReactComponent as ChevronRightIcon } from 'app/icons/chevron-right.svg';
import { ReactComponent as CopyIcon } from 'app/icons/copy-old.svg';
import PageLayout from 'app/layouts/PageLayout';
import { useFiatCurrency } from 'lib/fiat-currency';
import { T, TID, t } from 'lib/i18n';
import { useTempleClient } from 'lib/temple/front';
import { getDerivationPath } from 'lib/temple/helpers';
import { TempleAccountType } from 'lib/temple/types';
import { useAlert } from 'lib/ui';
import { getAccountAddressForEvm, getAccountAddressForTezos } from 'temple/accounts';
import { useAllAccounts, useCurrentAccountId, useTezosMainnetChain } from 'temple/front';
import { useAllAccounts, useCurrentAccountId } from 'temple/front';
import { TempleChainKind, TempleChainTitle } from 'temple/types';

import { BalanceFiat } from '../Home/OtherComponents/MainBanner/BalanceFiat';

import { AccountAddressesModal } from './account-addresses-modal';
import { EditAccountNameModal } from './edit-account-name-modal';
import { RemoveAccountModal } from './remove-account-modal';
Expand Down Expand Up @@ -54,18 +51,14 @@ export const AccountSettings = memo<AccountSettingsProps>(({ id }) => {
const { setAccountHidden } = useTempleClient();
useAllAccountsReactiveOnRemoval();
const allAccounts = useAllAccounts();
const {
selectedFiatCurrency: { symbol: fiatSymbol }
} = useFiatCurrency();

const [visibilityBeingChanged, setVisibilityBeingChanged] = useState(false);
const [currentModal, setCurrentModal] = useState<AccountSettingsModal | null>(null);
const shouldDisableVisibilityChange = visibilityBeingChanged || currentAccountId === id;

const account = useMemo(() => allAccounts.find(({ id: accountId }) => accountId === id), [allAccounts, id]);
const tezosAddress = account && getAccountAddressForTezos(account);
const evmAddress = account && getAccountAddressForEvm(account);
const tezosChain = useTezosMainnetChain();
const totalBalanceInDollar = useTotalBalance(tezosAddress ?? '', tezosChain.chainId);

const handleCopyClick = useCallback(() => {
if (account?.type !== TempleAccountType.HD) {
Expand Down Expand Up @@ -160,7 +153,7 @@ export const AccountSettings = memo<AccountSettingsProps>(({ id }) => {
<T id="totalBalance" />:
</span>
<span className="ml-1.5 text-gray-900 text-xs leading-4">
<BalanceFiat totalBalanceInDollar={totalBalanceInDollar} currency={fiatSymbol} />
<TotalEquity account={account} currency="fiat" />
</span>
</div>
<span className="text-gray-600 text-xxxs leading-3 font-medium">
Expand Down
1 change: 0 additions & 1 deletion src/app/pages/Collectibles/CollectiblesTab/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@ import DropdownWrapper from 'app/atoms/DropdownWrapper';
import { IconButton } from 'app/atoms/IconButton';
import { ScrollBackUpButton } from 'app/atoms/ScrollBackUpButton';
import { SimpleInfiniteScroll } from 'app/atoms/SimpleInfiniteScroll';
import { SuspenseContainer } from 'app/atoms/SuspenseContainer';
import { useCollectiblesListingLogic } from 'app/hooks/use-collectibles-listing-logic';
import { ReactComponent as EditingIcon } from 'app/icons/editing.svg';
import { ReactComponent as FiltersIcon } from 'app/icons/filteroff.svg';
Expand Down
2 changes: 1 addition & 1 deletion src/app/pages/Home/ActionButtonsBar.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ import { createUrl, Link, To } from 'lib/woozie';
import { createLocationState } from 'lib/woozie/location';
import { useAccount } from 'temple/front';

import { HomeSelectors } from './Home.selectors';
import { HomeSelectors } from './selectors';

const tippyPropsMock = {
trigger: 'mouseenter',
Expand Down
11 changes: 8 additions & 3 deletions src/app/pages/Home/Home.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -20,11 +20,12 @@ import { useOnboardingProgress } from '../Onboarding/hooks/useOnboardingProgress
import Onboarding from '../Onboarding/Onboarding';

import { ActionButtonsBar } from './ActionButtonsBar';
import MainBanner from './OtherComponents/MainBanner';
import { AssetBanner } from './OtherComponents/AssetBanner';
import { ScamTokenAlert } from './OtherComponents/ScamTokenAlert';
import { TezosAssetTab } from './OtherComponents/TezosAssetTab';
import { TokenPageSelectors } from './OtherComponents/TokenPage.selectors';
import { TokensTab } from './OtherComponents/Tokens/Tokens';
import { TotalEquityBanner } from './OtherComponents/TotalEquityBanner';
import { TokenPageSelectors } from './selectors';

interface Props {
tezosChainId?: string | null;
Expand Down Expand Up @@ -70,7 +71,11 @@ const Home = memo<Props>(({ tezosChainId, assetSlug }) => {
{showScamTokenAlert && <ScamTokenAlert />}

<div className="flex flex-col pt-1 px-4">
<MainBanner tezosChainId={tezosChainId} assetSlug={assetSlug} />
{tezosChainId && assetSlug ? (
<AssetBanner tezosChainId={tezosChainId} assetSlug={assetSlug} />
) : (
<TotalEquityBanner />
)}

<ActionButtonsBar tezosChainId={tezosChainId} assetSlug={assetSlug} />

Expand Down
91 changes: 91 additions & 0 deletions src/app/pages/Home/OtherComponents/AssetBanner.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,91 @@
import React, { memo } from 'react';

import Money from 'app/atoms/Money';
import AddressChip from 'app/templates/AddressChip';
import { AssetIcon } from 'app/templates/AssetIcon';
import Balance from 'app/templates/Balance';
import InFiat from 'app/templates/InFiat';
import { setAnotherSelector, setTestID } from 'lib/analytics';
import { getAssetName, getAssetSymbol, useAssetMetadata } from 'lib/metadata';
import { UNDER_DEVELOPMENT_MSG } from 'temple/evm/under_dev_msg';
import { useAccountAddressForTezos, useTezosChainByChainId } from 'temple/front';
import { TezosNetworkEssentials } from 'temple/networks';

import { HomeSelectors, TokenPageSelectors } from '../selectors';

interface Props {
tezosChainId: string;
assetSlug: string;
}

export const AssetBanner = memo<Props>(({ tezosChainId, assetSlug }) => {
const accountTezAddress = useAccountAddressForTezos();
const network = useTezosChainByChainId(tezosChainId);

return network && accountTezAddress ? (
<TezosAssetBanner network={network} assetSlug={assetSlug} accountPkh={accountTezAddress} />
) : (
UNDER_DEVELOPMENT_MSG
);
});

interface TezosTezosAssetBanner {
network: TezosNetworkEssentials;
accountPkh: string;
assetSlug: string;
}

const TezosAssetBanner = memo<TezosTezosAssetBanner>(({ network, accountPkh, assetSlug }) => {
const assetMetadata = useAssetMetadata(assetSlug, network.chainId);
const assetName = getAssetName(assetMetadata);
const assetSymbol = getAssetSymbol(assetMetadata);

return (
<>
<div className="flex justify-between items-center my-3">
<div className="flex items-center">
<AssetIcon tezosChainId={network.chainId} assetSlug={assetSlug} size={24} className="flex-shrink-0" />

<div
className="text-sm font-normal text-gray-700 truncate flex-1 ml-2"
{...setTestID(TokenPageSelectors.tokenName)}
{...setAnotherSelector('name', assetName)}
>
{assetName}
</div>
</div>

<AddressChip
address={accountPkh}
tezosNetwork={network}
modeSwitchTestId={HomeSelectors.addressModeSwitchButton}
/>
</div>

<div className="flex items-center text-2xl">
<Balance network={network} address={accountPkh} assetSlug={assetSlug}>
{balance => (
<div className="flex flex-col">
<div className="flex text-2xl">
<Money smallFractionFont={false} fiat>
{balance}
</Money>
<span className="ml-1">{assetSymbol}</span>
</div>

<InFiat tezosChainId={network.chainId} assetSlug={assetSlug} volume={balance} smallFractionFont={false}>
{({ balance, symbol }) => (
<div style={{ lineHeight: '19px' }} className="mt-1 text-base text-gray-500 flex">
alex-tsx marked this conversation as resolved.
Show resolved Hide resolved
<span className="mr-1">β‰ˆ</span>
{balance}
<span className="ml-1">{symbol}</span>
</div>
)}
</InFiat>
</div>
)}
</Balance>
</div>
</>
);
});
Loading