2023-09-12 18:52:03 +00:00
|
|
|
import { useDataProvider } from '@vegaprotocol/data-provider';
|
|
|
|
import type { MarketMaybeWithData } from '@vegaprotocol/markets';
|
|
|
|
import { marketListProvider } from '@vegaprotocol/markets';
|
|
|
|
import { useEffect } from 'react';
|
|
|
|
import type { CellClickedEvent } from 'ag-grid-community';
|
|
|
|
import MarketListTable from './market-list-table';
|
|
|
|
import { useMarketClickHandler } from '../../lib/hooks/use-market-click-handler';
|
|
|
|
import { Interval } from '@vegaprotocol/types';
|
|
|
|
import { useYesterday } from '@vegaprotocol/react-helpers';
|
2023-11-16 03:10:39 +00:00
|
|
|
import { useT } from '../../lib/use-t';
|
2023-09-12 18:52:03 +00:00
|
|
|
|
|
|
|
const POLLING_TIME = 2000;
|
|
|
|
|
|
|
|
export const OpenMarkets = () => {
|
2023-11-16 03:10:39 +00:00
|
|
|
const t = useT();
|
2023-09-12 18:52:03 +00:00
|
|
|
const handleOnSelect = useMarketClickHandler();
|
|
|
|
const yesterday = useYesterday();
|
|
|
|
const { data, error, reload } = useDataProvider({
|
|
|
|
dataProvider: marketListProvider,
|
|
|
|
variables: {
|
|
|
|
since: new Date(yesterday).toISOString(),
|
|
|
|
interval: Interval.INTERVAL_I1H,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
const interval = setInterval(() => {
|
|
|
|
reload();
|
|
|
|
}, POLLING_TIME);
|
|
|
|
return () => {
|
|
|
|
clearInterval(interval);
|
|
|
|
};
|
|
|
|
}, [reload]);
|
|
|
|
|
|
|
|
return (
|
|
|
|
<MarketListTable
|
|
|
|
rowData={data}
|
|
|
|
onCellClicked={({
|
|
|
|
data,
|
|
|
|
column,
|
|
|
|
event,
|
|
|
|
}: CellClickedEvent<MarketMaybeWithData>) => {
|
|
|
|
if (!data) return;
|
|
|
|
|
|
|
|
// prevent navigating to the market page if any of the below cells are clicked
|
2023-11-28 22:13:12 +00:00
|
|
|
// event.preventDefault or event.stopPropagation do not seem to apply for ag-grid
|
2023-09-12 18:52:03 +00:00
|
|
|
const colId = column.getColId();
|
|
|
|
|
|
|
|
if (
|
|
|
|
[
|
|
|
|
'tradableInstrument.instrument.product.settlementAsset.symbol',
|
|
|
|
'market-actions',
|
|
|
|
].includes(colId)
|
|
|
|
) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// @ts-ignore metaKey exists
|
|
|
|
handleOnSelect(data.id, event ? event.metaKey : false);
|
|
|
|
}}
|
|
|
|
overlayNoRowsTemplate={error ? error.message : t('No markets')}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
};
|