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: 19, 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: 6 }, { i: 'accountInfo', x: 6, y: 1, w: 6, h: 14, minW: 6 }, { i: 'tradeForm', x: 0, y: 2, w: 12, h: 17, minW: 6 }, { i: 'orderbook', x: 0, y: 3, w: 6, h: 17, minW: 6 }, { i: 'marketTrades', x: 6, y: 3, w: 6, h: 17, minW: 6 }, { i: 'userInfo', x: 0, y: 4, 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 } 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)} measureBeforeMount >
) : ( ) } export default TradePageGrid