import { gql } from '@apollo/client'; import { Splash } from '@vegaprotocol/ui-toolkit'; import { useRouter } from 'next/router'; import React, { useEffect, useState } from 'react'; import debounce from 'lodash/debounce'; import { PageQueryContainer } from '../../components/page-query-container'; import { TradeGrid, TradePanels } from './trade-grid'; import { t } from '@vegaprotocol/react-helpers'; import { useGlobalStore } from '../../stores'; import { LandingDialog } from '@vegaprotocol/market-list'; import type { Market, MarketVariables } from './__generated__/Market'; import { Interval } from '@vegaprotocol/types'; // Top level page query const MARKET_QUERY = gql` query Market($marketId: ID!, $interval: Interval!, $since: String!) { market(id: $marketId) { id name tradingMode state decimalPlaces positionDecimalPlaces data { market { id } markPrice indicativeVolume bestBidVolume bestOfferVolume bestStaticBidVolume bestStaticOfferVolume indicativeVolume trigger } tradableInstrument { instrument { name code metadata { tags } } } marketTimestamps { open close } candles(interval: $interval, since: $since) { open close volume } } } `; const MarketPage = ({ id }: { id?: string }) => { const { query } = useRouter(); const { w } = useWindowSize(); const store = useGlobalStore(); // Default to first marketId query item if found const marketId = id || (Array.isArray(query.marketId) ? query.marketId[0] : query.marketId); // Cache timestamp for yesterday to prevent full unmount of market page when // a rerender occurs const [yTimestamp] = useState(() => { const yesterday = Math.round(new Date().getTime() / 1000) - 24 * 3600; return new Date(yesterday * 1000).toISOString(); }); if (!marketId) { return (

{t('Not found')}

); } return ( query={MARKET_QUERY} data-testid="market" options={{ variables: { marketId, interval: Interval.I1H, since: yTimestamp, }, fetchPolicy: 'network-only', }} render={({ market }) => { if (!market) { return {t('Market not found')}; } return ( <> {w > 960 ? ( ) : ( )} store.setLandingDialog(isOpen)} /> ); }} /> ); }; MarketPage.getInitialProps = () => ({ page: 'market', }); export default MarketPage; const useWindowSize = () => { const [windowSize, setWindowSize] = useState(() => { if (typeof window !== 'undefined') { return { w: window.innerWidth, h: window.innerHeight, }; } // Something sensible for server rendered page return { w: 1200, h: 900, }; }); useEffect(() => { const handleResize = debounce(({ target }) => { setWindowSize({ w: target.innerWidth, h: target.innerHeight, }); }, 300); window.addEventListener('resize', handleResize); return () => { window.removeEventListener('resize', handleResize); }; }, []); return windowSize; };