import dynamic from 'next/dynamic'
import { Responsive, WidthProvider } from 'react-grid-layout'
import { round, max } from 'lodash'
import MobileTradePage from './mobile/MobileTradePage'
const TVChartContainer = dynamic(
() => import('../components/TradingView/index'),
{ ssr: false }
)
import { useEffect, useState } from 'react'
import FloatingElement from '../components/FloatingElement'
import Orderbook from '../components/Orderbook'
import AccountInfo from './AccountInfo'
import UserMarketInfo from './UserMarketInfo'
import TradeForm from './trade_form/TradeForm'
import UserInfo from './UserInfo'
import RecentMarketTrades from './RecentMarketTrades'
import useMangoStore from '../stores/useMangoStore'
import useLocalStorageState from '../hooks/useLocalStorageState'
import { useViewport } from '../hooks/useViewport'
import MarketDetails from './MarketDetails'
const ResponsiveGridLayout = WidthProvider(Responsive)
export const defaultLayouts = {
xl: [
{ i: 'tvChart', x: 0, y: 0, w: 6, h: 27 },
{ i: 'marketPosition', x: 9, y: 4, w: 3, h: 13 },
{ i: 'accountInfo', x: 9, y: 3, w: 3, h: 14 },
{ i: 'orderbook', x: 6, y: 0, w: 3, h: 17 },
{ i: 'tradeForm', x: 9, y: 1, w: 3, h: 17 },
{ i: 'marketTrades', x: 6, y: 1, w: 3, h: 10 },
{ i: 'userInfo', x: 0, y: 2, w: 9, h: 19 },
],
lg: [
{ i: 'tvChart', x: 0, y: 0, w: 6, h: 27, minW: 2 },
{ i: 'marketPosition', x: 9, y: 2, w: 3, h: 13, minW: 2 },
{ i: 'accountInfo', x: 9, y: 1, w: 3, h: 14, minW: 2 },
{ i: 'orderbook', x: 6, y: 2, w: 3, h: 17, minW: 2 },
{ i: 'tradeForm', x: 9, y: 0, w: 3, h: 17, minW: 3 },
{ i: 'marketTrades', x: 6, y: 2, w: 3, h: 10, minW: 2 },
{ i: 'userInfo', x: 0, y: 3, w: 9, h: 19, minW: 6 },
],
md: [
{ i: 'tvChart', x: 0, y: 0, w: 8, h: 25, minW: 2 },
{ i: 'marketPosition', x: 8, y: 1, w: 4, h: 11, minW: 2 },
{ i: 'accountInfo', x: 8, y: 0, w: 4, h: 14, minW: 2 },
{ i: 'orderbook', x: 0, y: 2, w: 4, h: 19, minW: 2 },
{ i: 'tradeForm', x: 4, y: 2, w: 4, h: 17, minW: 3 },
{ i: 'marketTrades', x: 8, y: 2, w: 4, h: 19, minW: 2 },
{ i: 'userInfo', x: 0, y: 3, w: 12, h: 19, minW: 6 },
],
sm: [
{ i: 'tvChart', x: 0, y: 0, w: 12, h: 20, minW: 6 },
{ i: 'marketPosition', x: 0, y: 1, w: 6, h: 14, minW: 2 },
{ i: 'accountInfo', x: 6, y: 1, w: 6, h: 14, minW: 2 },
{ i: 'tradeForm', x: 0, y: 2, w: 12, h: 17, minW: 3 },
{ i: 'orderbook', x: 0, y: 3, w: 6, h: 17, minW: 3 },
{ i: 'marketTrades', x: 6, y: 3, w: 6, h: 17, minW: 3 },
{ i: 'userInfo', x: 0, y: 4, w: 12, h: 19, minW: 6 },
],
xs: [
{ i: 'tvChart', x: 0, y: 0, w: 12, h: 25, minW: 6 },
{ i: 'marketPosition', x: 0, y: 1, w: 6, h: 13, minW: 2 },
{ i: 'accountInfo', x: 0, y: 2, w: 6, h: 16, minW: 2 },
{ i: 'tradeForm', x: 0, y: 3, w: 12, h: 17, minW: 3 },
{ i: 'orderbook', x: 0, y: 4, w: 6, h: 17, minW: 3 },
{ i: 'marketTrades', x: 0, y: 5, w: 6, h: 17, minW: 2 },
{ i: 'userInfo', x: 0, y: 6, w: 12, h: 19, minW: 6 },
],
}
export const GRID_LAYOUT_KEY = 'mangoSavedLayouts-3.1.6'
export const breakpoints = { xl: 1600, lg: 1280, md: 1024, sm: 768, xs: 0 }
const getCurrentBreakpoint = () => {
return Responsive.utils.getBreakpointFromWidth(
breakpoints,
window.innerWidth - 63
)
}
const TradePageGrid = () => {
const { uiLocked } = useMangoStore((s) => s.settings)
const [savedLayouts, setSavedLayouts] = useLocalStorageState(
GRID_LAYOUT_KEY,
defaultLayouts
)
const { width } = useViewport()
const isMobile = width ? width < breakpoints.sm : false
const onLayoutChange = (layouts) => {
if (layouts) {
setSavedLayouts(layouts)
}
}
const onBreakpointChange = (newBreakpoint: string) => {
console.log('new breakpoint', newBreakpoint)
setCurrentBreakpoint(newBreakpoint)
}
const [orderbookDepth, setOrderbookDepth] = useState(10)
const [currentBreakpoint, setCurrentBreakpoint] = useState(null)
const [mounted, setMounted] = useState(false)
useEffect(() => {
const adjustOrderBook = (layouts, breakpoint?: string | null) => {
const bp = breakpoint ? breakpoint : getCurrentBreakpoint()
const orderbookLayout = layouts[bp].find((obj) => {
return obj.i === 'orderbook'
})
let depth = orderbookLayout.h * 0.891 - 5
depth = round(max([1, depth]))
setOrderbookDepth(depth)
}
adjustOrderBook(savedLayouts, currentBreakpoint)
}, [currentBreakpoint, savedLayouts])
useEffect(() => setMounted(true), [])
if (!mounted) return null
return !isMobile ? (
<>
onBreakpointChange(newBreakpoint)
}
onLayoutChange={(layout, layouts) => onLayoutChange(layouts)}
>
>
) : (
)
}
export default TradePageGrid