From 052aa2724c0cbff52cbe1c04af5910ddbec2fb6c Mon Sep 17 00:00:00 2001 From: brightiron <95196612+brightiron@users.noreply.github.com> Date: Wed, 22 Nov 2023 15:20:43 -0600 Subject: [PATCH] My balances improvements (#3029) * ohm balance card should display across sohm and ohm holdings * cleanup debug * use protocol metrics price * update failing test * update mocks --- .../Cooler/hooks/useGetCoolerBalance.tsx | 3 - src/views/MyBalances/MyCoolerLoans.tsx | 2 +- src/views/MyBalances/MyOhmBalances.tsx | 76 +++++++------------ src/views/MyBalances/index.tsx | 22 ++++-- src/views/Range/__tests__/Range.test.tsx | 4 +- .../Range/__tests__/RangeBondsLower.test.tsx | 4 +- .../Range/__tests__/RangeBondsUpper.test.tsx | 4 +- src/views/Range/index.tsx | 4 +- 8 files changed, 50 insertions(+), 69 deletions(-) diff --git a/src/views/Lending/Cooler/hooks/useGetCoolerBalance.tsx b/src/views/Lending/Cooler/hooks/useGetCoolerBalance.tsx index de8875c5e7..c47041f7dd 100644 --- a/src/views/Lending/Cooler/hooks/useGetCoolerBalance.tsx +++ b/src/views/Lending/Cooler/hooks/useGetCoolerBalance.tsx @@ -15,10 +15,7 @@ export const useGetCoolerBalance = ({ coolerAddress }: { coolerAddress?: string try { if (!coolerAddress) return new DecimalBigNumber("0", 18); const contract = IERC20__factory.connect(GOHM_ADDRESSES[networks.MAINNET], provider); - console.log("beforeBalanceOf"); const balance = await contract.balanceOf(coolerAddress); - console.log("balance", balance.toString()); - return new DecimalBigNumber(balance, 18); } catch { return new DecimalBigNumber("0", 18); diff --git a/src/views/MyBalances/MyCoolerLoans.tsx b/src/views/MyBalances/MyCoolerLoans.tsx index 8a67269572..4932993af9 100644 --- a/src/views/MyBalances/MyCoolerLoans.tsx +++ b/src/views/MyBalances/MyCoolerLoans.tsx @@ -91,7 +91,7 @@ export const MyCoolerLoans = ({ balance, balanceUSD }: { balance: string; balanc const daysLeft = Math.floor((expiryDate.getTime() - currentDate.getTime()) / (1000 * 3600 * 24)); const percentComplete = ((requestDays - daysLeft) / requestDays) * 100; return ( - + diff --git a/src/views/MyBalances/MyOhmBalances.tsx b/src/views/MyBalances/MyOhmBalances.tsx index 5841fc4389..09753e0eec 100644 --- a/src/views/MyBalances/MyOhmBalances.tsx +++ b/src/views/MyBalances/MyOhmBalances.tsx @@ -4,47 +4,21 @@ import { useState } from "react"; import { Link as RouterLink } from "react-router-dom"; import { ReactComponent as WalletIcon } from "src/assets/icons/wallet.svg"; import { MigrationNotification } from "src/components/MigrationNotification"; -import { isTestnet } from "src/helpers"; import { DecimalBigNumber } from "src/helpers/DecimalBigNumber/DecimalBigNumber"; -import { nonNullable } from "src/helpers/types/nonNullable"; -import { - useOhmBalance, - useSohmBalance, - useV1OhmBalance, - useV1SohmBalance, - useWsohmBalance, -} from "src/hooks/useBalance"; +import { useOhmBalance, useSohmBalance, useV1OhmBalance, useV1SohmBalance } from "src/hooks/useBalance"; import { useTestableNetworks } from "src/hooks/useTestableNetworks"; -import { NetworkId } from "src/networkDetails"; -import { useNetwork } from "wagmi"; -export const MyOhmBalances = ({ walletBalance }: { walletBalance?: DecimalBigNumber }) => { - const { chain = { id: 1 } } = useNetwork(); +export const MyOhmBalances = () => { const networks = useTestableNetworks(); const ohmBalances = useOhmBalance(); - const wsohmBalances = useWsohmBalance(); + const { data: v1OhmBalance = new DecimalBigNumber("0", 9) } = useV1OhmBalance()[networks.MAINNET]; const { data: v1SohmBalance = new DecimalBigNumber("0", 9) } = useV1SohmBalance()[networks.MAINNET]; const { data: sOhmBalance = new DecimalBigNumber("0", 9) } = useSohmBalance()[networks.MAINNET]; - const ohmTokens = isTestnet(chain.id) - ? [ohmBalances[NetworkId.TESTNET_GOERLI].data, ohmBalances[NetworkId.ARBITRUM_GOERLI].data] - : [ohmBalances[NetworkId.MAINNET].data, ohmBalances[NetworkId.ARBITRUM].data]; - - const wsohmTokens = [ - wsohmBalances[NetworkId.MAINNET].data, - wsohmBalances[NetworkId.ARBITRUM].data, - wsohmBalances[NetworkId.AVALANCHE].data, - ]; - - const totalOhmBalance = ohmTokens - .filter(nonNullable) - .reduce((res, bal) => res.add(bal), new DecimalBigNumber("0", 18)); - - const totalWsohmBalance = wsohmTokens - .filter(nonNullable) - .reduce((res, bal) => res.add(bal), new DecimalBigNumber("0", 18)); const [modalOpen, setModalOpen] = useState(false); + const dust = new DecimalBigNumber("0.000001", 9); + return ( @@ -58,24 +32,26 @@ export const MyOhmBalances = ({ walletBalance }: { walletBalance?: DecimalBigNum - - - - - + {ohmBalances[networks.MAINNET].data?.gt(dust) && ( + + + + + + + + {Number(ohmBalances[networks.MAINNET].data?.toString()).toFixed(4) || "0.00"} OHM + - - {Number(ohmBalances[networks.MAINNET].data?.toString()).toFixed(4) || "0.00"} OHM - + + Wrap + - - Wrap - - - {ohmBalances[networks.ARBITRUM].data?.gt(new DecimalBigNumber("0")) && ( + )} + {ohmBalances[networks.ARBITRUM].data?.gt(dust) && ( @@ -94,7 +70,7 @@ export const MyOhmBalances = ({ walletBalance }: { walletBalance?: DecimalBigNum )} - {sOhmBalance.gt(new DecimalBigNumber("0")) && ( + {sOhmBalance.gt(dust) && ( @@ -113,7 +89,7 @@ export const MyOhmBalances = ({ walletBalance }: { walletBalance?: DecimalBigNum )} - {v1OhmBalance.gt(new DecimalBigNumber("0")) && ( + {v1OhmBalance.gt(dust) && ( @@ -136,7 +112,7 @@ export const MyOhmBalances = ({ walletBalance }: { walletBalance?: DecimalBigNum )} - {v1SohmBalance.gt(new DecimalBigNumber("0")) && ( + {v1SohmBalance.gt(dust) && ( diff --git a/src/views/MyBalances/index.tsx b/src/views/MyBalances/index.tsx index 6725c2e1a5..20638b05d7 100644 --- a/src/views/MyBalances/index.tsx +++ b/src/views/MyBalances/index.tsx @@ -18,7 +18,7 @@ import { useWsohmBalance, } from "src/hooks/useBalance"; import { useCurrentIndex } from "src/hooks/useCurrentIndex"; -import { useOhmPrice } from "src/hooks/usePrices"; +import { useOhmPrice } from "src/hooks/useProtocolMetrics"; import { useTestableNetworks } from "src/hooks/useTestableNetworks"; import { NetworkId } from "src/networkDetails"; import { useGetClearingHouse } from "src/views/Lending/Cooler/hooks/useGetClearingHouse"; @@ -42,7 +42,7 @@ export const MyBalances: FC = () => { const { address } = useAccount(); const networks = useTestableNetworks(); const { chain = { id: 1 } } = useNetwork(); - const { data: ohmPrice = 0 } = useOhmPrice(); + const ohmPrice = useOhmPrice({}) || 0; const { data: currentIndex = new DecimalBigNumber("0", 9) } = useCurrentIndex(); const { data: v1OhmBalance = new DecimalBigNumber("0", 9) } = useV1OhmBalance()[networks.MAINNET]; const { data: v1SohmBalance = new DecimalBigNumber("0", 9) } = useV1SohmBalance()[networks.MAINNET]; @@ -112,12 +112,11 @@ export const MyBalances: FC = () => { .filter(nonNullable) .reduce((res, bal) => res.add(bal), new DecimalBigNumber("0", 18)); - const formattedohmBalance = totalOhmBalance.toString({ decimals: 4, trim: false, format: true }); const formattedgOhmBalance = totalGohmBalance.toString({ decimals: 4, trim: false, format: true }); const gOhmPrice = ohmPrice * currentIndex.toApproxNumber(); const coolerBalance = totalCoolerBalance.toString({ decimals: 4, trim: false, format: true }); - const tokenArray = [ + const myOhmBalances = [ { assetValue: totalOhmBalance.toApproxNumber() * ohmPrice, }, @@ -130,6 +129,10 @@ export const MyBalances: FC = () => { { assetValue: v1SohmBalance.toApproxNumber() * ohmPrice, }, + ]; + + const tokenArray = [ + ...myOhmBalances, { assetValue: gOhmPrice * totalWsohmBalance.toApproxNumber(), }, @@ -139,6 +142,11 @@ export const MyBalances: FC = () => { ]; const walletTotalValueUSD = Object.values(tokenArray).reduce((totalValue, token) => totalValue + token.assetValue, 0); + const myOhmBalancesTotalValueUSD = Object.values(myOhmBalances).reduce( + (totalValue, token) => totalValue + token.assetValue, + 0, + ); + const isMobileScreen = useMediaQuery("(max-width: 513px)"); const theme = useTheme(); const { isConnected } = useAccount(); @@ -193,14 +201,14 @@ export const MyBalances: FC = () => { - {formattedohmBalance} OHM + {(myOhmBalancesTotalValueUSD / (ohmPrice !== 0 ? ohmPrice : 1)).toFixed(4)} OHM - {formatCurrency(ohmPrice * Number(totalOhmBalance.toString()), 2)} + {formatCurrency(myOhmBalancesTotalValueUSD, 2)} - {Number(totalOhmBalance.toString()) > 0 ? : } + {Number(myOhmBalancesTotalValueUSD.toString()) > 0 ? : } diff --git a/src/views/Range/__tests__/Range.test.tsx b/src/views/Range/__tests__/Range.test.tsx index 4d150e474e..811202f644 100644 --- a/src/views/Range/__tests__/Range.test.tsx +++ b/src/views/Range/__tests__/Range.test.tsx @@ -4,7 +4,7 @@ import { formatCurrency } from "src/helpers"; import { DecimalBigNumber } from "src/helpers/DecimalBigNumber/DecimalBigNumber"; import * as Balance from "src/hooks/useBalance"; import { useContractAllowance } from "src/hooks/useContractAllowance"; -import * as Prices from "src/hooks/usePrices"; +import * as Prices from "src/hooks/useProtocolMetrics"; import { connectWallet, invalidAddress } from "src/testHelpers"; import { fireEvent, render, screen } from "src/testUtils"; import * as IERC20Factory from "src/typechain/factories/IERC20__factory"; @@ -45,7 +45,7 @@ const defaultStatesWithApproval = () => { symbol: vi.fn().mockReturnValue("DAI"), }); //@ts-expect-error - vi.spyOn(Prices, "useOhmPrice").mockReturnValue({ data: "18.209363085" }); + vi.spyOn(Prices, "useOhmPrice").mockReturnValue("18.209363085"); //@ts-ignore rangeOperator.mockReturnValue({ diff --git a/src/views/Range/__tests__/RangeBondsLower.test.tsx b/src/views/Range/__tests__/RangeBondsLower.test.tsx index 45dc3ea77e..cd4b54e459 100644 --- a/src/views/Range/__tests__/RangeBondsLower.test.tsx +++ b/src/views/Range/__tests__/RangeBondsLower.test.tsx @@ -3,7 +3,7 @@ import * as Contract from "src/constants/contracts"; import { DecimalBigNumber } from "src/helpers/DecimalBigNumber/DecimalBigNumber"; import * as Balance from "src/hooks/useBalance"; import { useContractAllowance } from "src/hooks/useContractAllowance"; -import * as Prices from "src/hooks/usePrices"; +import * as Prices from "src/hooks/useProtocolMetrics"; import { connectWallet } from "src/testHelpers"; import { fireEvent, render, screen } from "src/testUtils"; import * as BondTellerContract from "src/typechain/factories/BondTeller__factory"; @@ -26,7 +26,7 @@ const setupTest = () => { symbol: vi.fn().mockReturnValue("DAI"), }); //@ts-expect-error - vi.spyOn(Prices, "useOhmPrice").mockReturnValue({ data: "13.209363085" }); + vi.spyOn(Prices, "useOhmPrice").mockReturnValue("13.209363085"); BondTellerContract.BondTeller__factory.connect = vi.fn().mockReturnValue({ purchase: vi.fn().mockReturnValue({ diff --git a/src/views/Range/__tests__/RangeBondsUpper.test.tsx b/src/views/Range/__tests__/RangeBondsUpper.test.tsx index f0088cd7a9..8eadbd322e 100644 --- a/src/views/Range/__tests__/RangeBondsUpper.test.tsx +++ b/src/views/Range/__tests__/RangeBondsUpper.test.tsx @@ -4,7 +4,7 @@ import { formatCurrency } from "src/helpers"; import { DecimalBigNumber } from "src/helpers/DecimalBigNumber/DecimalBigNumber"; import * as Balance from "src/hooks/useBalance"; import { useContractAllowance } from "src/hooks/useContractAllowance"; -import * as Prices from "src/hooks/usePrices"; +import * as Prices from "src/hooks/useProtocolMetrics"; import { connectWallet } from "src/testHelpers"; import { fireEvent, render, screen } from "src/testUtils"; import * as BondTellerContract from "src/typechain/factories/BondTeller__factory"; @@ -46,7 +46,7 @@ describe("Upper Wall Active Bond Market", () => { symbol: vi.fn().mockReturnValue("DAI"), }); //@ts-expect-error - vi.spyOn(Prices, "useOhmPrice").mockReturnValue({ data: "13.209363085" }); + vi.spyOn(Prices, "useOhmPrice").mockReturnValue("13.209363085"); //@ts-ignore BondTellerContract.BondTeller__factory.connect = vi.fn().mockReturnValue({ purchase: vi.fn().mockReturnValue({ diff --git a/src/views/Range/index.tsx b/src/views/Range/index.tsx index 27d3f5a58e..25cb670fc8 100644 --- a/src/views/Range/index.tsx +++ b/src/views/Range/index.tsx @@ -10,7 +10,7 @@ import { formatNumber, parseBigNumber } from "src/helpers"; import { DecimalBigNumber } from "src/helpers/DecimalBigNumber/DecimalBigNumber"; import { useBalance } from "src/hooks/useBalance"; import { usePathForNetwork } from "src/hooks/usePathForNetwork"; -import { useOhmPrice } from "src/hooks/usePrices"; +import { useOhmPrice } from "src/hooks/useProtocolMetrics"; import { useTestableNetworks } from "src/hooks/useTestableNetworks"; import { DetermineRangePrice, OperatorReserveSymbol, RangeBondMaxPayout, RangeData } from "src/views/Range/hooks"; import RangeChart from "src/views/Range/RangeChart"; @@ -44,7 +44,7 @@ export const Range = () => { const { data: reserveBalance = new DecimalBigNumber("0", 18) } = useBalance(DAI_ADDRESSES)[networks.MAINNET]; const { data: ohmBalance = new DecimalBigNumber("0", 9) } = useBalance(OHM_ADDRESSES)[networks.MAINNET]; - const { data: currentPrice = 0 } = useOhmPrice(); + const currentPrice = useOhmPrice({}) || 0; const maxString = sellActive ? `Max You Can Sell` : `Max You Can Buy`;