2023-06-27 00:10:22 +00:00
|
|
|
import type { ComponentProps } from 'react';
|
|
|
|
import { Splash } from '@vegaprotocol/ui-toolkit';
|
2023-05-16 16:57:36 +00:00
|
|
|
import { DepthChartContainer } from '@vegaprotocol/market-depth';
|
2023-08-02 14:29:41 +00:00
|
|
|
import {
|
|
|
|
CandlesChartContainer,
|
|
|
|
CandlesMenu,
|
|
|
|
} from '@vegaprotocol/candles-chart';
|
2023-08-10 15:02:46 +00:00
|
|
|
import { Filter, OpenOrdersMenu } from '@vegaprotocol/orders';
|
2023-05-16 16:57:36 +00:00
|
|
|
import { NO_MARKET } from './constants';
|
2023-08-15 11:26:13 +00:00
|
|
|
import { TradesContainer } from '../../components/trades-container';
|
2023-07-24 08:37:18 +00:00
|
|
|
import { OrderbookContainer } from '../../components/orderbook-container';
|
2023-06-27 00:10:22 +00:00
|
|
|
import { FillsContainer } from '../../components/fills-container';
|
|
|
|
import { PositionsContainer } from '../../components/positions-container';
|
|
|
|
import { AccountsContainer } from '../../components/accounts-container';
|
|
|
|
import { LiquidityContainer } from '../../components/liquidity-container';
|
2023-09-20 09:11:03 +00:00
|
|
|
import { FundingContainer } from '../../components/funding-container';
|
2023-06-27 00:10:22 +00:00
|
|
|
import type { OrderContainerProps } from '../../components/orders-container';
|
|
|
|
import { OrdersContainer } from '../../components/orders-container';
|
2023-08-02 10:28:33 +00:00
|
|
|
import { StopOrdersContainer } from '../../components/stop-orders-container';
|
2023-08-10 15:02:46 +00:00
|
|
|
import { AccountsMenu } from '../../components/accounts-menu';
|
2023-08-22 09:17:10 +00:00
|
|
|
import { PositionsMenu } from '../../components/positions-menu';
|
2023-05-16 16:57:36 +00:00
|
|
|
|
|
|
|
type MarketDependantView =
|
|
|
|
| typeof CandlesChartContainer
|
|
|
|
| typeof DepthChartContainer
|
|
|
|
| typeof OrderbookContainer
|
|
|
|
| typeof TradesContainer;
|
|
|
|
|
|
|
|
type MarketDependantViewProps = ComponentProps<MarketDependantView>;
|
|
|
|
|
|
|
|
const requiresMarket = (View: MarketDependantView) => {
|
|
|
|
const WrappedComponent = (props: MarketDependantViewProps) =>
|
|
|
|
props.marketId ? <View {...props} /> : <Splash>{NO_MARKET}</Splash>;
|
|
|
|
WrappedComponent.displayName = `RequiresMarket(${View.name})`;
|
|
|
|
return WrappedComponent;
|
|
|
|
};
|
|
|
|
|
|
|
|
export type TradingView = keyof typeof TradingViews;
|
|
|
|
|
|
|
|
export const TradingViews = {
|
|
|
|
candles: {
|
|
|
|
label: 'Candles',
|
|
|
|
component: requiresMarket(CandlesChartContainer),
|
2023-08-02 14:29:41 +00:00
|
|
|
menu: CandlesMenu,
|
2023-05-16 16:57:36 +00:00
|
|
|
},
|
|
|
|
depth: {
|
|
|
|
label: 'Depth',
|
|
|
|
component: requiresMarket(DepthChartContainer),
|
|
|
|
},
|
|
|
|
liquidity: {
|
|
|
|
label: 'Liquidity',
|
|
|
|
component: requiresMarket(LiquidityContainer),
|
|
|
|
},
|
2023-09-20 09:11:03 +00:00
|
|
|
funding: {
|
|
|
|
label: 'Funding',
|
|
|
|
component: requiresMarket(FundingContainer),
|
|
|
|
},
|
2023-05-16 16:57:36 +00:00
|
|
|
orderbook: {
|
|
|
|
label: 'Orderbook',
|
|
|
|
component: requiresMarket(OrderbookContainer),
|
|
|
|
},
|
|
|
|
trades: {
|
|
|
|
label: 'Trades',
|
|
|
|
component: requiresMarket(TradesContainer),
|
|
|
|
},
|
2023-08-22 09:17:10 +00:00
|
|
|
positions: {
|
|
|
|
label: 'Positions',
|
|
|
|
component: PositionsContainer,
|
|
|
|
menu: PositionsMenu,
|
|
|
|
},
|
2023-05-16 16:57:36 +00:00
|
|
|
activeOrders: {
|
|
|
|
label: 'Active',
|
2023-06-27 00:10:22 +00:00
|
|
|
component: (props: OrderContainerProps) => (
|
|
|
|
<OrdersContainer {...props} filter={Filter.Open} />
|
2023-05-16 16:57:36 +00:00
|
|
|
),
|
2023-08-10 15:02:46 +00:00
|
|
|
menu: OpenOrdersMenu,
|
2023-05-16 16:57:36 +00:00
|
|
|
},
|
|
|
|
closedOrders: {
|
|
|
|
label: 'Closed',
|
2023-06-27 00:10:22 +00:00
|
|
|
component: (props: OrderContainerProps) => (
|
|
|
|
<OrdersContainer {...props} filter={Filter.Closed} />
|
2023-05-16 16:57:36 +00:00
|
|
|
),
|
|
|
|
},
|
|
|
|
rejectedOrders: {
|
|
|
|
label: 'Rejected',
|
2023-06-27 00:10:22 +00:00
|
|
|
component: (props: OrderContainerProps) => (
|
|
|
|
<OrdersContainer {...props} filter={Filter.Rejected} />
|
2023-05-16 16:57:36 +00:00
|
|
|
),
|
|
|
|
},
|
|
|
|
orders: {
|
|
|
|
label: 'All',
|
2023-06-27 00:10:22 +00:00
|
|
|
component: OrdersContainer,
|
2023-08-10 15:02:46 +00:00
|
|
|
menu: OpenOrdersMenu,
|
2023-05-16 16:57:36 +00:00
|
|
|
},
|
2023-08-02 10:28:33 +00:00
|
|
|
stopOrders: {
|
|
|
|
label: 'Stop',
|
|
|
|
component: StopOrdersContainer,
|
|
|
|
},
|
2023-08-10 15:02:46 +00:00
|
|
|
collateral: {
|
|
|
|
label: 'Collateral',
|
|
|
|
component: AccountsContainer,
|
|
|
|
menu: AccountsMenu,
|
|
|
|
},
|
2023-05-16 16:57:36 +00:00
|
|
|
fills: { label: 'Fills', component: FillsContainer },
|
|
|
|
};
|