import { DealTicketContainer } from '@vegaprotocol/deal-ticket'; import { MarketInfoAccordionContainer } from '@vegaprotocol/market-info'; import { OrderbookContainer } from '@vegaprotocol/market-depth'; import { OrderListContainer, Filter } from '@vegaprotocol/orders'; import type { OrderListContainerProps } from '@vegaprotocol/orders'; import { FillsContainer } from '@vegaprotocol/fills'; import { PositionsContainer } from '@vegaprotocol/positions'; import { TradesContainer } from '@vegaprotocol/trades'; import type { ComponentProps } from 'react'; import { DepthChartContainer } from '@vegaprotocol/market-depth'; import { CandlesChartContainer } from '@vegaprotocol/candles-chart'; import { Splash } from '@vegaprotocol/ui-toolkit'; import { AccountsContainer } from '../../components/accounts-container'; import { NO_MARKET } from './constants'; import { LiquidityContainer } from '../liquidity/liquidity'; type MarketDependantView = | typeof CandlesChartContainer | typeof DepthChartContainer | typeof DealTicketContainer | typeof MarketInfoAccordionContainer | typeof OrderbookContainer | typeof TradesContainer; type MarketDependantViewProps = ComponentProps; const requiresMarket = (View: MarketDependantView) => { const WrappedComponent = (props: MarketDependantViewProps) => props.marketId ? : {NO_MARKET}; WrappedComponent.displayName = `RequiresMarket(${View.name})`; return WrappedComponent; }; export type TradingView = keyof typeof TradingViews; export const TradingViews = { candles: { label: 'Candles', component: requiresMarket(CandlesChartContainer), }, depth: { label: 'Depth', component: requiresMarket(DepthChartContainer), }, liquidity: { label: 'Liquidity', component: requiresMarket(LiquidityContainer), }, ticket: { label: 'Ticket', component: requiresMarket(DealTicketContainer), }, info: { label: 'Info', component: requiresMarket(MarketInfoAccordionContainer), }, orderbook: { label: 'Orderbook', component: requiresMarket(OrderbookContainer), }, trades: { label: 'Trades', component: requiresMarket(TradesContainer), }, positions: { label: 'Positions', component: PositionsContainer }, activeOrders: { label: 'Active', component: (props: OrderListContainerProps) => ( ), }, closedOrders: { label: 'Closed', component: (props: OrderListContainerProps) => ( ), }, rejectedOrders: { label: 'Rejected', component: (props: OrderListContainerProps) => ( ), }, orders: { label: 'All', component: OrderListContainer, }, collateral: { label: 'Collateral', component: AccountsContainer }, fills: { label: 'Fills', component: FillsContainer }, };