2023-06-27 00:10:22 +00:00
|
|
|
import { useDataGridEvents } from '@vegaprotocol/datagrid';
|
2023-02-28 18:56:29 +00:00
|
|
|
import { t } from '@vegaprotocol/i18n';
|
2023-06-27 00:10:22 +00:00
|
|
|
import { PositionsManager } from '@vegaprotocol/positions';
|
2022-03-30 00:01:34 +00:00
|
|
|
import { Splash } from '@vegaprotocol/ui-toolkit';
|
2022-03-27 09:40:27 +00:00
|
|
|
import { useVegaWallet } from '@vegaprotocol/wallet';
|
2023-06-27 00:10:22 +00:00
|
|
|
import type { DataGridSlice } from '../../stores/datagrid-store-slice';
|
|
|
|
import { createDataGridSlice } from '../../stores/datagrid-store-slice';
|
2023-08-22 09:17:10 +00:00
|
|
|
import type { StateCreator } from 'zustand';
|
2023-06-27 00:10:22 +00:00
|
|
|
import { create } from 'zustand';
|
|
|
|
import { persist } from 'zustand/middleware';
|
2023-08-10 15:02:46 +00:00
|
|
|
import { useMarketClickHandler } from '../../lib/hooks/use-market-click-handler';
|
2022-03-25 12:40:08 +00:00
|
|
|
|
2023-09-28 19:14:32 +00:00
|
|
|
const AUTO_SIZE_COLUMNS = ['marketCode'];
|
|
|
|
|
2023-08-10 15:02:46 +00:00
|
|
|
export const PositionsContainer = ({ allKeys }: { allKeys?: boolean }) => {
|
|
|
|
const onMarketClick = useMarketClickHandler(true);
|
2023-05-25 10:59:08 +00:00
|
|
|
const { pubKey, pubKeys, isReadOnly } = useVegaWallet();
|
2022-03-30 00:01:34 +00:00
|
|
|
|
2023-08-22 09:17:10 +00:00
|
|
|
const showClosed = usePositionsStore((store) => store.showClosedMarkets);
|
2023-06-27 00:10:22 +00:00
|
|
|
const gridStore = usePositionsStore((store) => store.gridStore);
|
|
|
|
const updateGridStore = usePositionsStore((store) => store.updateGridStore);
|
2023-09-28 19:14:32 +00:00
|
|
|
const gridStoreCallbacks = useDataGridEvents(
|
|
|
|
gridStore,
|
|
|
|
updateGridStore,
|
|
|
|
AUTO_SIZE_COLUMNS
|
|
|
|
);
|
2023-06-27 00:10:22 +00:00
|
|
|
|
2022-10-03 18:12:34 +00:00
|
|
|
if (!pubKey) {
|
2022-03-30 00:01:34 +00:00
|
|
|
return (
|
|
|
|
<Splash>
|
2022-03-31 01:08:25 +00:00
|
|
|
<p>{t('Please connect Vega wallet')}</p>
|
2022-03-30 00:01:34 +00:00
|
|
|
</Splash>
|
|
|
|
);
|
|
|
|
}
|
2023-05-25 10:59:08 +00:00
|
|
|
|
|
|
|
const partyIds = [pubKey];
|
|
|
|
if (allKeys && pubKeys) {
|
|
|
|
partyIds.push(
|
|
|
|
...pubKeys
|
|
|
|
.map(({ publicKey }) => publicKey)
|
|
|
|
.filter((publicKey) => publicKey !== pubKey)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2023-01-31 16:04:52 +00:00
|
|
|
return (
|
|
|
|
<PositionsManager
|
2023-05-25 10:59:08 +00:00
|
|
|
partyIds={partyIds}
|
2023-01-31 16:04:52 +00:00
|
|
|
onMarketClick={onMarketClick}
|
|
|
|
isReadOnly={isReadOnly}
|
2023-06-27 00:10:22 +00:00
|
|
|
gridProps={gridStoreCallbacks}
|
2023-08-22 09:17:10 +00:00
|
|
|
showClosed={showClosed}
|
2023-01-31 16:04:52 +00:00
|
|
|
/>
|
|
|
|
);
|
2022-03-25 12:40:08 +00:00
|
|
|
};
|
2023-06-27 00:10:22 +00:00
|
|
|
|
2023-08-22 09:17:10 +00:00
|
|
|
type PositionsStoreSlice = {
|
|
|
|
showClosedMarkets: boolean;
|
|
|
|
toggleClosedMarkets: () => void;
|
|
|
|
};
|
|
|
|
|
|
|
|
const createPositionStoreSlice: StateCreator<PositionsStoreSlice> = (set) => ({
|
|
|
|
showClosedMarkets: false,
|
|
|
|
toggleClosedMarkets: () => {
|
|
|
|
set((curr) => {
|
|
|
|
return {
|
|
|
|
showClosedMarkets: !curr.showClosedMarkets,
|
|
|
|
};
|
|
|
|
});
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
export const usePositionsStore = create<PositionsStoreSlice & DataGridSlice>()(
|
|
|
|
persist(
|
|
|
|
(...args) => ({
|
|
|
|
...createPositionStoreSlice(...args),
|
|
|
|
...createDataGridSlice(...args),
|
|
|
|
}),
|
|
|
|
{
|
|
|
|
name: 'vega_positions_store',
|
|
|
|
}
|
|
|
|
)
|
2023-06-27 00:10:22 +00:00
|
|
|
);
|