2021-06-05 12:38:17 -07:00
|
|
|
import { useCallback, useEffect, useState } from 'react'
|
2021-06-05 11:40:56 -07:00
|
|
|
import useMangoStore from '../stores/useMangoStore'
|
|
|
|
import useConnection from './useConnection'
|
2021-06-05 12:38:17 -07:00
|
|
|
import useInterval from './useInterval'
|
2021-06-05 11:40:56 -07:00
|
|
|
import useMarket from './useMarket'
|
|
|
|
import useMarketList from './useMarketList'
|
|
|
|
|
2021-06-05 12:38:17 -07:00
|
|
|
const SECONDS = 1000
|
|
|
|
|
2021-06-05 11:40:56 -07:00
|
|
|
export default function useOraclePrice() {
|
|
|
|
const selectedMangoGroup = useMangoStore((s) => s.selectedMangoGroup.current)
|
|
|
|
const { connection } = useConnection()
|
|
|
|
const { marketAddress } = useMarket()
|
|
|
|
const { getMarketIndex } = useMarketList()
|
|
|
|
const [oraclePrice, setOraclePrice] = useState(null)
|
|
|
|
|
2021-06-05 12:38:17 -07:00
|
|
|
const fetchOraclePrice = useCallback(() => {
|
2021-06-05 11:40:56 -07:00
|
|
|
if (selectedMangoGroup) {
|
2021-06-12 19:03:05 -07:00
|
|
|
setOraclePrice(null)
|
2021-06-05 11:40:56 -07:00
|
|
|
const marketIndex = getMarketIndex(marketAddress)
|
|
|
|
selectedMangoGroup.getPrices(connection).then((prices) => {
|
|
|
|
const oraclePriceForMarket = prices[marketIndex]
|
|
|
|
setOraclePrice(oraclePriceForMarket)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}, [selectedMangoGroup, marketAddress])
|
2021-06-05 12:38:17 -07:00
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
fetchOraclePrice()
|
|
|
|
}, [fetchOraclePrice])
|
|
|
|
|
|
|
|
useInterval(() => {
|
|
|
|
fetchOraclePrice()
|
|
|
|
}, 20 * SECONDS)
|
2021-06-05 11:40:56 -07:00
|
|
|
|
|
|
|
return oraclePrice
|
|
|
|
}
|