fix vertical centering orderbook

This commit is contained in:
tjs 2022-09-26 01:32:48 -04:00 committed by saml33
parent b6d0e9c9f5
commit b44105f586
1 changed files with 76 additions and 88 deletions

View File

@ -358,11 +358,9 @@ const Orderbook = () => {
}, [serum3MarketExternal])
useEffect(() => {
function handleResize() {
verticallyCenterOrderbook()
}
handleResize()
window.addEventListener('resize', handleResize)
window.addEventListener('resize', verticallyCenterOrderbook)
// const id = setTimeout(verticallyCenterOrderbook, 400)
// return () => clearTimeout(id)
}, [verticallyCenterOrderbook])
const onGroupSizeChange = useCallback((groupSize: number) => {
@ -373,8 +371,6 @@ const Orderbook = () => {
setIsScrolled(true)
}, [])
if (!serum3MarketExternal) return null
return (
<div className="flex h-full flex-col">
<div className="flex items-center justify-between border-b border-th-bkg-3 px-4 py-2">
@ -408,74 +404,30 @@ const Orderbook = () => {
</button>
</Tooltip>
</div>
<Tooltip content="Grouping" placement="top">
<GroupSize
tickSize={serum3MarketExternal.tickSize}
onChange={onGroupSizeChange}
value={grouping}
/>
</Tooltip>
{serum3MarketExternal ? (
<Tooltip content="Grouping" placement="top">
<GroupSize
tickSize={serum3MarketExternal.tickSize}
onChange={onGroupSizeChange}
value={grouping}
/>
</Tooltip>
) : null}
</div>
<div className="grid grid-cols-2 px-4 pt-2 pb-1 text-xxs text-th-fgd-4">
<div className="col-span-1 text-right">{t('size')}</div>
<div className="col-span-1 text-right">{t('price')}</div>
</div>
{orderbookData ? (
<div
className="hide-scroll relative h-full overflow-y-scroll"
ref={orderbookElRef}
onScroll={handleScroll}
>
{showSells && orderbookData?.asks?.length
? depthArray.map((_x, index) => {
return (
<div key={index}>
{orderbookData?.asks[index] ? (
<MemoizedOrderbookRow
minOrderSize={serum3MarketExternal.minOrderSize}
tickSize={serum3MarketExternal.tickSize}
// hasOpenOrder={hasOpenOrderForPriceGroup(
// openOrderPrices,
// price,
// grouping
// )}
key={orderbookData?.asks[index].price}
price={orderbookData?.asks[index].price}
size={
displayCumulativeSize
? orderbookData?.asks[index].cumulativeSize
: orderbookData?.asks[index].size
}
side="sell"
sizePercent={
displayCumulativeSize
? orderbookData?.asks[index].maxSizePercent
: orderbookData?.asks[index].sizePercent
}
grouping={grouping}
/>
) : null}
</div>
)
})
: null}
{showBuys && showSells ? (
<div className="my-2 grid grid-cols-2 border-y border-th-bkg-3 py-2 px-4 text-xs text-th-fgd-4">
<div className="col-span-1 flex justify-between">
<div className="text-xxs">{t('spread')}</div>
<div className="font-mono">
{orderbookData?.spreadPercentage.toFixed(2)}%
</div>
</div>
<div className="col-span-1 text-right font-mono">
{orderbookData?.spread.toFixed(2)}
</div>
</div>
) : null}
{showBuys && orderbookData?.bids?.length
? depthArray.map((_x, index) => (
<div key={index}>
{orderbookData?.bids[index] ? (
<div
className="hide-scroll relative h-full overflow-y-scroll"
ref={orderbookElRef}
onScroll={handleScroll}
>
{showSells
? depthArray.map((_x, index) => {
return (
<div className="h-[24px]" key={index}>
{!!orderbookData?.asks[index] && serum3MarketExternal ? (
<MemoizedOrderbookRow
minOrderSize={serum3MarketExternal.minOrderSize}
tickSize={serum3MarketExternal.tickSize}
@ -484,34 +436,70 @@ const Orderbook = () => {
// price,
// grouping
// )}
price={orderbookData?.bids[index].price}
key={orderbookData?.asks[index].price}
price={orderbookData?.asks[index].price}
size={
displayCumulativeSize
? orderbookData?.bids[index].cumulativeSize
: orderbookData?.bids[index].size
? orderbookData?.asks[index].cumulativeSize
: orderbookData?.asks[index].size
}
side="buy"
side="sell"
sizePercent={
displayCumulativeSize
? orderbookData?.bids[index].maxSizePercent
: orderbookData?.bids[index].sizePercent
? orderbookData?.asks[index].maxSizePercent
: orderbookData?.asks[index].sizePercent
}
grouping={grouping}
/>
) : null}
</div>
))
: null}
</div>
) : (
<div className="space-y-[1px] px-4">
{depthArray.map((_x, index) => (
<SheenLoader className="flex flex-1" key={index}>
<div className="h-5 w-full rounded bg-th-bkg-2" />
</SheenLoader>
))}
</div>
)}
)
})
: null}
{showBuys && showSells ? (
<div className="my-2 grid grid-cols-2 border-y border-th-bkg-3 py-2 px-4 text-xs text-th-fgd-4">
<div className="col-span-1 flex justify-between">
<div className="text-xxs">{t('spread')}</div>
<div className="font-mono">
{orderbookData?.spreadPercentage.toFixed(2)}%
</div>
</div>
<div className="col-span-1 text-right font-mono">
{orderbookData?.spread.toFixed(2)}
</div>
</div>
) : null}
{showBuys
? depthArray.map((_x, index) => (
<div className="h-[24px]" key={index}>
{!!orderbookData?.bids[index] && serum3MarketExternal ? (
<MemoizedOrderbookRow
minOrderSize={serum3MarketExternal.minOrderSize}
tickSize={serum3MarketExternal.tickSize}
// hasOpenOrder={hasOpenOrderForPriceGroup(
// openOrderPrices,
// price,
// grouping
// )}
price={orderbookData?.bids[index].price}
size={
displayCumulativeSize
? orderbookData?.bids[index].cumulativeSize
: orderbookData?.bids[index].size
}
side="buy"
sizePercent={
displayCumulativeSize
? orderbookData?.bids[index].maxSizePercent
: orderbookData?.bids[index].sizePercent
}
grouping={grouping}
/>
) : null}
</div>
))
: null}
</div>
</div>
)
}