import { useCallback, useEffect, useState } from 'react'; import { Auction, Project } from 'gql-client'; import { Dialog, DialogTitle, DialogContent, DialogActions, } from '@mui/material'; import { CheckRoundFilledIcon, LoadingIcon, } from 'components/shared/CustomIcon'; import { useGQLClient } from 'context/GQLClientContext'; import { Button, Heading, Tag } from 'components/shared'; const WAIT_DURATION = 5000; export const AuctionCard = ({ project }: { project: Project }) => { const [auctionStatus, setAuctionStatus] = useState(''); const [deployerLrns, setDeployerLrns] = useState([]); const [fundsStatus, setFundsStatus] = useState(false); const [auctionDetails, setAuctionDetails] = useState(null); const [openDialog, setOpenDialog] = useState(false); const client = useGQLClient(); const getIconByAuctionStatus = (status: string) => status === 'completed' ? ( ) : ( ); const checkAuctionStatus = useCallback(async () => { const result = await client.getAuctionData(project.auctionId); setAuctionStatus(result.status); setAuctionDetails(result); setDeployerLrns(project.deployerLrns); setFundsStatus(project.fundsReleased); }, []); useEffect(() => { if (auctionStatus !== 'completed') { checkAuctionStatus(); const intervalId = setInterval(checkAuctionStatus, WAIT_DURATION); return () => clearInterval(intervalId); } if (auctionStatus === 'completed') { const fetchUpdatedProject = async () => { // Wait for 5 secs since the project is not immediately updated with deployer LRNs await new Promise((resolve) => setTimeout(resolve, WAIT_DURATION)); const updatedProject = await client.getProject(project.id); setDeployerLrns(updatedProject.project?.deployerLrns || []); }; fetchUpdatedProject(); } }, [auctionStatus, client]); const renderAuctionStatus = useCallback( () => ( {auctionStatus.toUpperCase()} ), [auctionStatus], ); const handleOpenDialog = () => setOpenDialog(true); const handleCloseDialog = () => setOpenDialog(false); return ( <>
Auction details
Auction Status
{renderAuctionStatus()}
Auction Id {project.auctionId}
{deployerLrns?.length > 0 && (
Deployer LRNs {deployerLrns.map((lrn, index) => (

{'\u2022'} {lrn}

))}
)}
Deployer Funds Status
{fundsStatus ? 'RELEASED' : 'LOCKED'}
Auction Details {auctionDetails && (
{JSON.stringify(auctionDetails, null, 2)}
)}
); };