mango-ui-v3/hooks/useTradeHistory.tsx

74 lines
2.2 KiB
TypeScript
Raw Normal View History

2021-04-14 23:16:36 -07:00
import { useEffect, useRef } from 'react'
import useMangoStore from '../stores/useMangoStore'
import useSerumStore from '../stores/useSerumStore'
2021-04-12 21:40:26 -07:00
import useMarket from './useMarket'
const byTimestamp = (a, b) => {
return (
new Date(b.loadTimestamp).getTime() - new Date(a.loadTimestamp).getTime()
)
}
const formatTradeHistory = (newTradeHistory) => {
return newTradeHistory
.flat()
.map((trade) => {
return {
...trade,
marketName: trade.marketName
? trade.marketName
: `${trade.baseCurrency}/${trade.quoteCurrency}`,
2021-04-14 23:16:36 -07:00
key: `${trade.orderId}-${trade.uuid}`,
liquidity: trade.maker || trade?.eventFlags?.maker ? 'Maker' : 'Taker',
}
})
.sort(byTimestamp)
}
2021-04-12 21:40:26 -07:00
const useFills = () => {
2021-04-14 23:16:36 -07:00
const fillsRef = useRef(useSerumStore.getState().fills)
const fills = fillsRef.current
useEffect(
() =>
useSerumStore.subscribe(
(fills) => (fillsRef.current = fills as []),
(state) => state.fills
),
[]
)
2021-04-12 21:40:26 -07:00
const { market, marketName } = useMarket()
const marginAccount = useMangoStore((s) => s.selectedMarginAccount.current)
const selectedMangoGroup = useMangoStore((s) => s.selectedMangoGroup.current)
if (!marginAccount || !selectedMangoGroup) return null
const marketIndex = selectedMangoGroup.getMarketIndex(market)
const openOrdersAccount = marginAccount.openOrdersAccounts[marketIndex]
2021-04-13 17:14:38 -07:00
if (!openOrdersAccount) return []
2021-04-12 21:40:26 -07:00
return fills
.filter((fill) => fill.openOrders.equals(openOrdersAccount.publicKey))
.map((fill) => ({ ...fill, marketName }))
}
export const useTradeHistory = () => {
2021-04-12 21:40:26 -07:00
const eventQueueFills = useFills()
2021-04-14 15:46:36 -07:00
const tradeHistory = useMangoStore((s) => s.tradeHistory)
2021-04-14 23:16:36 -07:00
const allTrades = []
if (eventQueueFills && eventQueueFills.length > 0) {
const newFills = eventQueueFills.filter(
(fill) =>
!tradeHistory.flat().find((t) => t.orderId === fill.orderId.toString())
)
const newTradeHistory = [...newFills, ...tradeHistory]
if (newFills.length > 0 && newTradeHistory.length !== allTrades.length) {
return formatTradeHistory(newTradeHistory)
}
2021-04-14 23:16:36 -07:00
}
2021-04-15 10:20:24 -07:00
return formatTradeHistory(tradeHistory)
}
export default useTradeHistory