import { useDataGridEvents } from '@vegaprotocol/datagrid'; import { Filter, OrderListManager } from '@vegaprotocol/orders'; import { Splash } from '@vegaprotocol/ui-toolkit'; import { useVegaWallet } from '@vegaprotocol/wallet'; import { useNavigateWithMeta } from '../../lib/hooks/use-market-click-handler'; import { create } from 'zustand'; import { persist } from 'zustand/middleware'; import type { DataGridStore } from '../../stores/datagrid-store-slice'; import { OrderStatus } from '@vegaprotocol/types'; import { Links } from '../../lib/links'; import { useT } from '../../lib/use-t'; const resolveNoRowsMessage = ( filter: Filter | undefined, t: ReturnType ) => { switch (filter) { case Filter.Open: return t('No open orders'); case Filter.Closed: return t('No closed orders'); case Filter.Rejected: return t('No rejected orders'); default: return t('No orders'); } }; export const FilterStatusValue = { [Filter.Open]: [OrderStatus.STATUS_ACTIVE, OrderStatus.STATUS_PARKED], [Filter.Closed]: [ OrderStatus.STATUS_CANCELLED, OrderStatus.STATUS_EXPIRED, OrderStatus.STATUS_FILLED, OrderStatus.STATUS_PARTIALLY_FILLED, OrderStatus.STATUS_STOPPED, ], [Filter.Rejected]: [OrderStatus.STATUS_REJECTED], }; export interface OrderContainerProps { filter?: Filter; } const AUTO_SIZE_COLUMNS = ['instrument-code']; export const OrdersContainer = ({ filter }: OrderContainerProps) => { const t = useT(); const { pubKey, isReadOnly } = useVegaWallet(); const navigate = useNavigateWithMeta(); const { gridState, updateGridState } = useOrderListGridState(filter); const gridStoreCallbacks = useDataGridEvents( gridState, (newState) => { updateGridState(filter, newState); }, AUTO_SIZE_COLUMNS ); if (!pubKey) { return {t('Please connect Vega wallet')}; } const noRowsMessage = resolveNoRowsMessage(filter, t); return ( { navigate(Links.MARKET(marketId), metaKey); }} onOrderTypeClick={(marketId, metaKey) => navigate(Links.LIQUIDITY(marketId), metaKey) } isReadOnly={isReadOnly} gridProps={gridStoreCallbacks} noRowsMessage={noRowsMessage} /> ); }; export const STORAGE_KEY = 'vega_order_list_store'; const useOrderListStore = create<{ open: DataGridStore; closed: DataGridStore; rejected: DataGridStore; all: DataGridStore; update: (filter: Filter | undefined, gridStore: DataGridStore) => void; }>()( persist( (set) => ({ open: {}, closed: {}, rejected: {}, all: {}, update: (filter, newStore) => { switch (filter) { case Filter.Open: { set((curr) => ({ open: { ...curr.open, ...newStore, }, })); return; } case Filter.Closed: { set((curr) => ({ closed: { ...curr.closed, ...newStore, }, })); return; } case Filter.Rejected: { set((curr) => ({ rejected: { ...curr.rejected, ...newStore, }, })); return; } case undefined: { set((curr) => ({ all: { ...curr.all, ...newStore, }, })); return; } } }, }), { name: STORAGE_KEY, } ) ); export const useOrderListGridState = (filter: Filter | undefined) => { const updateGridState = useOrderListStore((store) => store.update); const gridState = useOrderListStore((store) => { // Return the column/filter state for the given filter but ensuring that // each filter controlled by the tab is always applied switch (filter) { case Filter.Open: { return { columnState: store.open.columnState, filterModel: { ...store.open.filterModel, status: { value: FilterStatusValue[Filter.Open], }, }, }; } case Filter.Closed: { return { columnState: store.closed.columnState, filterModel: { ...store.closed.filterModel, status: { value: FilterStatusValue[Filter.Closed], }, }, }; } case Filter.Rejected: { return { columnState: store.rejected.columnState, filterModel: { ...store.rejected.filterModel, status: { value: FilterStatusValue[Filter.Rejected], }, }, }; } default: { return store.all; } } }); return { gridState, updateGridState }; };