mango-v4-ui/hooks/useSelectedMarket.ts

92 lines
2.6 KiB
TypeScript
Raw Normal View History

2022-11-19 17:40:06 -08:00
import { Serum3Market } from '@blockworks-foundation/mango-v4'
import mangoStore from '@store/mangoStore'
import { useMemo } from 'react'
2023-01-14 21:01:30 -08:00
import useJupiterMints from './useJupiterMints'
2022-11-19 17:40:06 -08:00
import useMangoGroup from './useMangoGroup'
export default function useSelectedMarket() {
const { group } = useMangoGroup()
const selectedMarket = mangoStore((s) => s.selectedMarket.current)
2023-01-14 21:01:30 -08:00
const { mangoTokens } = useJupiterMints()
2022-11-19 17:40:06 -08:00
const marketAddress = useMemo(() => {
return selectedMarket?.publicKey.toString()
}, [selectedMarket])
2022-11-19 17:40:06 -08:00
const price: number = useMemo(() => {
if (!group) return 0
if (selectedMarket instanceof Serum3Market) {
const baseBank = group.getFirstBankByTokenIndex(
selectedMarket.baseTokenIndex
)
return baseBank.uiPrice
} else if (selectedMarket) {
return selectedMarket._uiPrice
} else return 0
}, [selectedMarket, group])
2022-11-20 20:52:03 -08:00
const serumOrPerpMarket = useMemo(() => {
const group = mangoStore.getState().group
if (!group || !selectedMarket) return
if (selectedMarket instanceof Serum3Market) {
return group?.getSerum3ExternalMarket(selectedMarket.serumMarketExternal)
} else {
return selectedMarket
}
}, [selectedMarket])
2023-01-14 21:01:30 -08:00
const baseSymbol = useMemo(() => {
return selectedMarket?.name.split(/-|\//)[0]
}, [selectedMarket])
const baseLogoURI = useMemo(() => {
if (!baseSymbol || !mangoTokens.length) return ''
const token =
2023-01-18 03:18:57 -08:00
mangoTokens.find((t) => t.symbol.toUpperCase() === baseSymbol) ||
mangoTokens.find((t) => t.symbol.toUpperCase()?.includes(baseSymbol))
2023-01-14 21:01:30 -08:00
if (token) {
return token.logoURI
}
return ''
}, [baseSymbol, mangoTokens])
const quoteBank = useMemo(() => {
const group = mangoStore.getState().group
if (!group || !selectedMarket) return
const tokenIdx =
selectedMarket instanceof Serum3Market
? selectedMarket.quoteTokenIndex
: selectedMarket?.settleTokenIndex
return group?.getFirstBankByTokenIndex(tokenIdx)
}, [selectedMarket])
const quoteSymbol = useMemo(() => {
return quoteBank?.name
}, [quoteBank])
const quoteLogoURI = useMemo(() => {
if (!quoteSymbol || !mangoTokens.length) return ''
2023-01-18 03:18:57 -08:00
const token = mangoTokens.find(
(t) => t.symbol.toUpperCase() === quoteSymbol
)
2023-01-14 21:01:30 -08:00
if (token) {
return token.logoURI
}
return ''
}, [quoteSymbol, mangoTokens])
return {
selectedMarket,
selectedMarketAddress: marketAddress,
2023-01-14 21:01:30 -08:00
price,
serumOrPerpMarket,
baseSymbol,
quoteBank,
2023-01-14 21:01:30 -08:00
quoteSymbol,
baseLogoURI,
quoteLogoURI,
}
2022-11-19 17:40:06 -08:00
}