import React, { useCallback } from 'react'; import { useMarketList } from '@vegaprotocol/market-list'; import { t } from '@vegaprotocol/react-helpers'; import { useAssetDetailsDialogStore } from '@vegaprotocol/assets'; import { Link as UILink } from '@vegaprotocol/ui-toolkit'; import type { Market, OnCellClickHandler } from '../select-market'; import { ColumnKind, columns, SelectMarketTableHeader, SelectMarketTableRow, } from '../select-market'; import { WelcomeDialogHeader } from './welcome-dialog-header'; import { Link, useNavigate, useParams } from 'react-router-dom'; import { EMPTY_MARKET_ID } from '../constants'; import { useGlobalStore } from '../../stores'; import { ProposedMarkets } from './proposed-markets'; export const SelectMarketLandingTable = ({ markets, onClose, }: { markets: Market[] | null; onClose: () => void; }) => { const params = useParams(); const navigate = useNavigate(); const isEmpty = params.marketId === EMPTY_MARKET_ID; const marketId = isEmpty ? undefined : params.marketId; const { update } = useGlobalStore((store) => ({ update: store.update, })); const onSelect = useCallback( (id: string) => { if (id && id !== marketId) { update({ marketId: id }); navigate(`/markets/${id}`); } }, [marketId, update, navigate] ); const onSelectMarket = useCallback( (id: string) => { onSelect(id); 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 ( <> ); };