import type { ReactNode } from 'react';
import { useMemo, useState } from 'react';
import { t, useDataProvider } from '@vegaprotocol/react-helpers';
import {
Dialog,
Icon,
Intent,
Loader,
Link,
Popover,
} from '@vegaprotocol/ui-toolkit';
import { useMarketList } from '@vegaprotocol/market-list';
import type {
MarketWithCandles,
MarketWithData,
} from '@vegaprotocol/market-list';
import { useVegaWallet } from '@vegaprotocol/wallet';
import type { PositionFieldsFragment } from '@vegaprotocol/positions';
import { positionsDataProvider } from '@vegaprotocol/positions';
import {
SelectMarketTableHeader,
SelectMarketTableRow,
} from './select-market-table';
import type { Column, OnCellClickHandler } from './select-market-columns';
import {
columnHeadersPositionMarkets,
columnsPositionMarkets,
columnHeaders,
columns,
} from './select-market-columns';
type Market = MarketWithCandles & MarketWithData;
export const SelectMarketLandingTable = ({
markets,
onSelect,
onCellClick,
}: {
markets: Market[] | null;
onSelect: (id: string) => void;
onCellClick: OnCellClickHandler;
}) => {
return (
<>
{markets?.map((market, i) => (
))}
{'Or view full market list'}
>
);
};
export const SelectAllMarketsTableBody = ({
markets,
positions,
onSelect,
onCellClick,
headers = columnHeaders,
tableColumns = (market) => columns(market, onSelect, onCellClick),
}: {
markets?: Market[] | null;
positions?: PositionFieldsFragment[];
title?: string;
onSelect: (id: string) => void;
onCellClick: OnCellClickHandler;
headers?: Column[];
tableColumns?: (market: Market, openVolume?: string) => Column[];
}) => {
if (!markets) return null;
return (
<>
{/* Border styles required to create space between tbody elements margin/padding don't work */}
{markets?.map((market, i) => (
p.market.id === market.id)?.openVolume
)}
/>
))}
>
);
};
export const SelectMarketPopover = ({
marketName,
onSelect,
onCellClick,
}: {
marketName: string;
onSelect: (id: string) => void;
onCellClick: OnCellClickHandler;
}) => {
const triggerClasses =
'sm:text-lg md:text-xl lg:text-2xl flex items-center gap-2 whitespace-nowrap hover:text-neutral-500 dark:hover:text-neutral-300';
const { pubKey } = useVegaWallet();
const [open, setOpen] = useState(false);
const { data, loading: marketsLoading } = useMarketList();
const variables = useMemo(() => ({ partyId: pubKey }), [pubKey]);
const { data: party, loading: positionsLoading } = useDataProvider({
dataProvider: positionsDataProvider,
noUpdate: true,
variables,
skip: !pubKey,
});
const onSelectMarket = (marketId: string) => {
onSelect(marketId);
setOpen(false);
};
const iconClass = open ? 'rotate-180' : '';
const markets = useMemo(
() =>
data?.filter((market) =>
party?.positionsConnection?.edges?.find(
(edge) => edge.node.market.id === market.id
)
),
[data, party]
);
return (
{marketName}
}
>
{marketsLoading || (pubKey && positionsLoading) ? (
Loading market data
) : (
{pubKey && (party?.positionsConnection?.edges?.length ?? 0) > 0 ? (
<>
{t('My markets')}
edge.node)
.map((edge) => edge.node)}
onSelect={onSelectMarket}
onCellClick={onCellClick}
headers={columnHeadersPositionMarkets}
tableColumns={(market, openVolume) =>
columnsPositionMarkets(
market,
onSelectMarket,
openVolume,
onCellClick
)
}
/>
>
) : null}
{t('All markets')}
)}
);
};
const TableTitle = ({ children }: { children: ReactNode }) => {
return (
{children}
|
);
};
export const SelectMarketDialog = ({
dialogOpen,
setDialogOpen,
onSelect,
onCellClick,
}: {
dialogOpen: boolean;
setDialogOpen: (open: boolean) => void;
title?: string;
onSelect: (id: string) => void;
onCellClick: OnCellClickHandler;
}) => {
const onSelectMarket = (id: string) => {
onSelect(id);
setDialogOpen(false);
};
return (
);
};
interface LandingDialogContainerProps {
onSelect: (id: string) => void;
onCellClick: OnCellClickHandler;
}
const LandingDialogContainer = ({
onSelect,
onCellClick,
}: LandingDialogContainerProps) => {
const { data, loading, error } = useMarketList();
if (error) {
return (
{t('Failed to load markets')}
);
}
if (loading) {
return (
);
}
return (
);
};