import React, { useCallback } from 'react'; import { useMarketList } from '@vegaprotocol/markets'; import { t } from '@vegaprotocol/i18n'; import { useAssetDetailsDialogStore } from '@vegaprotocol/assets'; import { Link as UILink, TinyScroll } from '@vegaprotocol/ui-toolkit'; import type { OnCellClickHandler } from '../select-market'; import type { MarketMaybeWithDataAndCandles } from '@vegaprotocol/markets'; import { ColumnKind, columns, SelectMarketTableHeader, SelectMarketTableRow, } from '../select-market'; import { WelcomeDialogHeader } from './welcome-dialog-header'; import { Link } from 'react-router-dom'; import { ProposedMarkets } from './proposed-markets'; import { Links, Routes } from '../../pages/client-router'; import { useMarketClickHandler } from '../../lib/hooks/use-market-click-handler'; export const SelectMarketLandingTable = ({ markets, onClose, }: { markets: MarketMaybeWithDataAndCandles[] | null; onClose: () => void; }) => { const onSelect = useMarketClickHandler(); const onSelectMarket = useCallback( (id: string, metaKey?: boolean) => { onSelect(id, metaKey); if (!metaKey) { onClose(); } }, [onSelect, onClose] ); const { open: openAssetDetailsDialog } = useAssetDetailsDialogStore(); const onCellClick = useCallback( (e, kind, value) => { if (value && kind === ColumnKind.Asset) { openAssetDetailsDialog(value, e.target as HTMLElement); } }, [openAssetDetailsDialog] ); const showProposed = (markets?.length || 0) <= 5; return ( <>

{t('Select a market to get started...')}

{markets?.map((market, i) => ( ))}
onClose()} > {'Or view full market list'}
{showProposed && } ); }; interface LandingDialogContainerProps { onClose: () => void; } export const WelcomeLandingDialog = ({ onClose, }: LandingDialogContainerProps) => { const { data, loading, error } = useMarketList(); if (error) { return (

{t('Failed to load markets')}

); } if (loading) { return (

{t('Loading...')}

); } return ( <> ); };