mango-ui-v3/components/TradePageGrid.tsx

165 lines
5.2 KiB
TypeScript
Raw Normal View History

2021-04-02 11:26:21 -07:00
import dynamic from 'next/dynamic'
import { Responsive, WidthProvider } from 'react-grid-layout'
2022-03-29 19:46:21 -07:00
import round from 'lodash/round'
import max from 'lodash/max'
import MobileTradePage from './mobile/MobileTradePage'
2021-04-02 11:26:21 -07:00
const TVChartContainer = dynamic(
() => import('../components/TradingView/index'),
{ ssr: false }
)
import { useEffect, useState } from 'react'
2021-04-02 11:26:21 -07:00
import FloatingElement from '../components/FloatingElement'
2021-06-17 14:07:10 -07:00
import Orderbook from '../components/Orderbook'
2021-09-26 06:20:51 -07:00
import TradeForm from './trade_form/TradeForm'
import UserInfo from './UserInfo'
2021-07-19 10:13:03 -07:00
import RecentMarketTrades from './RecentMarketTrades'
import useMangoStore from '../stores/useMangoStore'
2021-04-16 13:17:33 -07:00
import useLocalStorageState from '../hooks/useLocalStorageState'
import { useViewport } from '../hooks/useViewport'
import MarketDetails from './MarketDetails'
2021-04-02 11:26:21 -07:00
const ResponsiveGridLayout = WidthProvider(Responsive)
export const defaultLayouts = {
xxl: [
2022-06-16 03:57:11 -07:00
{ i: 'tvChart', x: 0, y: 0, w: 8, h: 19 },
{ i: 'tradeForm', x: 8, y: 0, w: 2, h: 19 },
2022-06-22 18:30:30 -07:00
{ i: 'orderbook', x: 10, y: 0, w: 2, h: 25 },
{ i: 'marketTrades', x: 10, y: 1, w: 2, h: 13 },
2022-06-16 03:57:11 -07:00
{ i: 'userInfo', x: 0, y: 1, w: 10, h: 19 },
],
xl: [
2022-06-16 03:57:11 -07:00
{ i: 'tvChart', x: 0, y: 0, w: 6, h: 19, minW: 2 },
{ i: 'tradeForm', x: 6, y: 0, w: 3, h: 19, minW: 3 },
2022-06-22 18:30:30 -07:00
{ i: 'orderbook', x: 9, y: 0, w: 3, h: 25, minW: 2 },
{ i: 'marketTrades', x: 9, y: 0, w: 3, h: 13, minW: 2 },
2022-06-16 03:57:11 -07:00
{ i: 'userInfo', x: 0, y: 1, w: 9, h: 19, minW: 6 },
2021-05-01 21:31:55 -07:00
],
lg: [
2022-06-16 03:57:11 -07:00
{ i: 'tvChart', x: 0, y: 0, w: 6, h: 19, minW: 2 },
{ i: 'tradeForm', x: 6, y: 0, w: 3, h: 19, minW: 2 },
2022-06-22 18:30:30 -07:00
{ i: 'orderbook', x: 9, y: 0, w: 3, h: 25, minW: 2 },
{ i: 'marketTrades', x: 9, y: 1, w: 3, h: 13, minW: 2 },
2022-06-16 03:57:11 -07:00
{ i: 'userInfo', x: 0, y: 1, w: 9, h: 19, minW: 6 },
2021-05-01 21:31:55 -07:00
],
md: [
{ i: 'tvChart', x: 0, y: 0, w: 12, h: 16, minW: 2 },
{ i: 'tradeForm', x: 0, y: 1, w: 4, h: 19, minW: 3 },
{ i: 'orderbook', x: 4, y: 1, w: 4, h: 19, minW: 2 },
{ i: 'marketTrades', x: 8, y: 1, w: 4, h: 19, minW: 2 },
{ i: 'userInfo', x: 0, y: 2, w: 12, h: 19, minW: 6 },
],
2021-05-01 21:31:55 -07:00
sm: [
2022-01-31 07:52:28 -08:00
{ i: 'tvChart', x: 0, y: 0, w: 12, h: 20, minW: 6 },
{ i: 'tradeForm', x: 0, y: 1, w: 12, h: 17, minW: 6 },
{ i: 'orderbook', x: 0, y: 2, w: 6, h: 19, minW: 3 },
{ i: 'marketTrades', x: 6, y: 2, w: 6, h: 19, minW: 3 },
2022-06-16 03:57:11 -07:00
{ i: 'userInfo', x: 0, y: 3, w: 12, h: 19, minW: 6 },
2021-05-01 21:31:55 -07:00
],
}
export const GRID_LAYOUT_KEY = 'mangoSavedLayouts-3.1.9'
export const breakpoints = { xxl: 1600, xl: 1440, lg: 1170, md: 960, sm: 768 }
2021-05-01 21:31:55 -07:00
2021-12-09 09:23:19 -08:00
const getCurrentBreakpoint = () => {
return Responsive.utils.getBreakpointFromWidth(
breakpoints,
window.innerWidth - 63
)
}
2022-03-28 08:42:18 -07:00
const TradePageGrid: React.FC = () => {
const [mounted, setMounted] = useState(false)
const { uiLocked } = useMangoStore((s) => s.settings)
2021-04-16 13:17:33 -07:00
const [savedLayouts, setSavedLayouts] = useLocalStorageState(
2021-05-01 21:31:55 -07:00
GRID_LAYOUT_KEY,
2021-04-16 13:17:33 -07:00
defaultLayouts
)
const { width } = useViewport()
const isMobile = width ? width < breakpoints.sm : false
2021-04-16 13:17:33 -07:00
2021-04-16 14:54:46 -07:00
const onLayoutChange = (layouts) => {
if (layouts) {
setSavedLayouts(layouts)
}
2021-04-16 13:17:33 -07:00
}
2022-03-28 08:42:18 -07:00
const [orderbookDepth, setOrderbookDepth] = useState(10)
const [currentBreakpoint, setCurrentBreakpoint] = useState<string | null>(
null
)
2021-08-28 00:49:41 -07:00
const onBreakpointChange = (newBreakpoint: string) => {
setCurrentBreakpoint(newBreakpoint)
}
useEffect(() => {
const adjustOrderBook = (layouts, breakpoint?: string | null) => {
const bp = breakpoint ? breakpoint : getCurrentBreakpoint()
const orderbookLayout = layouts[bp].find((obj) => {
return obj.i === 'orderbook'
})
2022-06-22 18:30:30 -07:00
let depth = orderbookLayout.h * 0.921 - 5
2022-03-29 06:02:29 -07:00
const maxNum = max([1, depth])
if (typeof maxNum === 'number') {
depth = round(maxNum)
}
2021-08-28 00:49:41 -07:00
setOrderbookDepth(depth)
}
adjustOrderBook(savedLayouts, currentBreakpoint)
}, [currentBreakpoint, savedLayouts])
useEffect(() => setMounted(true), [])
2022-02-09 02:55:54 -08:00
if (!mounted) return null
2021-08-16 10:00:43 -07:00
return !isMobile ? (
<>
2022-02-04 22:04:07 -08:00
<div className="pt-2">
<MarketDetails />
</div>
<ResponsiveGridLayout
layouts={savedLayouts ? savedLayouts : defaultLayouts}
breakpoints={breakpoints}
2022-01-31 16:21:17 -08:00
cols={{ xl: 12, lg: 12, md: 12, sm: 12 }}
rowHeight={15}
isDraggable={!uiLocked}
isResizable={!uiLocked}
onBreakpointChange={(newBreakpoint) =>
onBreakpointChange(newBreakpoint)
}
onLayoutChange={(layout, layouts) => onLayoutChange(layouts)}
measureBeforeMount
>
<div key="tvChart">
<FloatingElement className="h-full pl-0 md:pl-0 md:pr-1 md:pb-1 md:pt-2.5">
<TVChartContainer />
</FloatingElement>
</div>
<div key="orderbook">
<Orderbook depth={orderbookDepth} />
</div>
<div key="tradeForm">
2021-09-24 05:24:17 -07:00
<TradeForm />
</div>
<div key="marketTrades">
<FloatingElement className="h-full">
<RecentMarketTrades />
</FloatingElement>
</div>
<div key="userInfo">
<FloatingElement className="h-full">
<UserInfo />
</FloatingElement>
</div>
</ResponsiveGridLayout>
</>
) : (
<MobileTradePage />
2021-04-02 11:26:21 -07:00
)
}
export default TradePageGrid