import { Link } from 'react-router-dom'; import { Splash } from '@vegaprotocol/ui-toolkit'; import { formatNumber } from '@vegaprotocol/utils'; import { type useTeams } from '../../lib/hooks/use-teams'; import { useT } from '../../lib/use-t'; import { Table } from '../table'; import { Rank } from './graphics/rank'; import { Links } from '../../lib/links'; import { TeamAvatar } from './team-avatar'; export const CompetitionsLeaderboard = ({ data, }: { data: ReturnType['data']; }) => { const t = useT(); const num = (n?: number | string) => (!n ? '-' : formatNumber(n, 0)); if (!data || data.length === 0) { return {t('Could not find any teams')}; } return ( { // leaderboard place or medal let rank: number | React.ReactNode = td.rank; if (rank === 1) rank = ; if (rank === 2) rank = ; if (rank === 3) rank = ; const avatar = ( ); return { rank, avatar, team: ( { // Its possible for a tx to be submitted with an empty space as team name td.name.trim() !== '' ? td.name : t('[empty]') } ), earned: num(td.totalQuantumRewards), games: num(td.totalGamesPlayed), status: td.closed ? t('Closed') : t('Open'), volume: num(td.totalQuantumVolume), }; })} /> ); };