2023-06-27 00:10:22 +00:00
|
|
|
import { useDataGridEvents } from '@vegaprotocol/datagrid';
|
2023-08-02 15:34:04 +00:00
|
|
|
import { Filter, OrderListManager } from '@vegaprotocol/orders';
|
2023-06-27 00:10:22 +00:00
|
|
|
import { t } from '@vegaprotocol/i18n';
|
|
|
|
import { Splash } from '@vegaprotocol/ui-toolkit';
|
|
|
|
import { useVegaWallet } from '@vegaprotocol/wallet';
|
|
|
|
import {
|
|
|
|
useMarketClickHandler,
|
|
|
|
useMarketLiquidityClickHandler,
|
|
|
|
} 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';
|
|
|
|
|
|
|
|
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 {
|
|
|
|
marketId?: string;
|
|
|
|
filter?: Filter;
|
|
|
|
}
|
|
|
|
|
|
|
|
export const OrdersContainer = ({ marketId, filter }: OrderContainerProps) => {
|
|
|
|
const { pubKey, isReadOnly } = useVegaWallet();
|
|
|
|
const onMarketClick = useMarketClickHandler(true);
|
|
|
|
const onOrderTypeClick = useMarketLiquidityClickHandler();
|
|
|
|
const { gridState, updateGridState } = useOrderListGridState(filter);
|
|
|
|
const gridStoreCallbacks = useDataGridEvents(gridState, (newState) => {
|
|
|
|
updateGridState(filter, newState);
|
|
|
|
});
|
|
|
|
|
|
|
|
if (!pubKey) {
|
|
|
|
return <Splash>{t('Please connect Vega wallet')}</Splash>;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<OrderListManager
|
|
|
|
partyId={pubKey}
|
|
|
|
marketId={marketId}
|
|
|
|
filter={filter}
|
|
|
|
onMarketClick={onMarketClick}
|
|
|
|
onOrderTypeClick={onOrderTypeClick}
|
|
|
|
isReadOnly={isReadOnly}
|
|
|
|
gridProps={gridStoreCallbacks}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
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 };
|
|
|
|
};
|