Skip to content
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
217 changes: 135 additions & 82 deletions src/pages/Contests.page.jsx
Original file line number Diff line number Diff line change
@@ -1,95 +1,148 @@
import React, {useContext, useEffect} from 'react'
import {Button, Card, Divider, Image, List, Row, Skeleton, Typography} from 'antd'
import Meta from 'antd/lib/card/Meta';
import {parseDate} from "../utils/utils";
import {BarChartOutlined, ClockCircleOutlined, EnterOutlined} from '@ant-design/icons'
import './contests.page.css'
import React, { useContext, useEffect } from "react";
import {
Button,
Card,
Divider,
Image,
List,
Row,
Skeleton,
Typography,
} from "antd";
import Meta from "antd/lib/card/Meta";
import { parseDate } from "../utils/utils";
import {
BarChartOutlined,
ClockCircleOutlined,
EnterOutlined,
} from "@ant-design/icons";
import "./contests.page.css";
import GlobalContext from "../context/GlobalContext";

const {Title} = Typography;

const { Title } = Typography;

function Contests(props) {
const globalContext = useContext(GlobalContext);

const globalContext = useContext(GlobalContext)

useEffect(() => {
// eslint-disable-next-line
}, []);
useEffect(() => {
// eslint-disable-next-line
}, []);

async function handleEnterContest(contest) {
props.history.push('/contests/' + contest.contest_id.id)
async function handleEnterContest(contest) {
try {
props.history.push("/contests/" + contest.contest_id.id);
} catch (e) {
console.log(e);
}
async function handleEnterLeaderboard(contest) {
props.history.push('/leaderboard/' + contest.contest_id.id)
}
async function handleEnterLeaderboard(contest) {
try {
props.history.push("/leaderboard/" + contest.contest_id.id);
} catch (e) {
console.log(e);
}
}

return (
<div key={2} style={{padding: '2% 4%'}}>
<Title>Contests</Title>
<Divider/>

<List
grid={{
gutter: 256,
xs: 1,
sm: 2,
md: 3,
lg: 3,
xl: 4,
xxl: 6,
}}
style={{
padding: '1% 2%'
}}
rowKey='id'
dataSource={globalContext.contests !== null ? globalContext.contests : [{}, {}, {}, {}]}
renderItem={item => (
<List.Item key={item.id}>
<Card
type="inner"
hoverable
style={{width: 280, minHeight: '170px'}}
cover={<Image alt="example" className={'contests-img'}
src={item.contest_id ? item.contest_id.banner_image : ''}
/>}
>
<Skeleton loading={globalContext.isContestsLoading}/>
{!globalContext.isContestsLoading && <><Meta
title={<Typography.Title level={4}>{item.contest_id.name}</Typography.Title>}
/>
<br/>
<p><ClockCircleOutlined/>&nbsp;
<strong>Starts:</strong> {parseDate(item.contest_id.start_time)}
</p>
<p><ClockCircleOutlined/>&nbsp;
<strong>Ends:</strong> {parseDate(item.contest_id.end_time)}</p>
<Divider/>
</>}
<Row align={'center'}>
{
globalContext.isContestsLoading || (!globalContext.isContestsLoading && (new Date(item.contest_id.end_time) < new Date()))?
<Button
onClick={() => handleEnterLeaderboard(item)}
icon={<BarChartOutlined/>} type="primary">Leaderboard
</Button>:
<Button
disabled={globalContext.isContestsLoading || (!globalContext.isContestsLoading && (new Date(item.contest_id.start_time) > new Date() || new Date(item.contest_id.end_time) < new Date()))}
onClick={() => handleEnterContest(item)}
icon={<EnterOutlined/>} type="primary">Enter
</Button>
}



return (
<div key={2} style={{ padding: "2% 4%" }}>
<Title>Contests</Title>
<Divider />

</Row>
</Card>
</List.Item>
<List
grid={{
gutter: 256,
xs: 1,
sm: 2,
md: 3,
lg: 3,
xl: 4,
xxl: 6,
}}
style={{
padding: "1% 2%",
}}
rowKey="id"
dataSource={
globalContext.contests !== null
? globalContext.contests
: [{}, {}, {}, {}]
}
renderItem={(item) => (
<List.Item key={item.id}>
<Card
type="inner"
hoverable
style={{ width: 280, minHeight: "170px" }}
cover={
<Image
alt="example"
className={"contests-img"}
src={
item.contest_id
? item.contest_id.banner_image
: ""
}
/>
}
>
<Skeleton loading={globalContext.isContestsLoading} />
{!globalContext.isContestsLoading && (
<>
<Meta
title={
<Typography.Title level={4}>
{item.contest_id.name}
</Typography.Title>
}
/>
<br />
<p>
<ClockCircleOutlined />
&nbsp;
<strong>Starts:</strong>{" "}
{parseDate(item.contest_id.start_time)}
</p>
<p>
<ClockCircleOutlined />
&nbsp;
<strong>Ends:</strong> {parseDate(item.contest_id.end_time)}
</p>
<Divider />
</>
)}
<Row align={"center"}>
{globalContext.isContestsLoading ||
(!globalContext.isContestsLoading &&
new Date(item.contest_id.end_time) < new Date()) ? (
<Button
onClick={() => handleEnterLeaderboard(item)}
icon={<BarChartOutlined />}
type="primary"
>
Leaderboard
</Button>
) : (
<Button
disabled={
globalContext.isContestsLoading ||
(!globalContext.isContestsLoading &&
(new Date(item.contest_id.start_time) > new Date() ||
new Date(item.contest_id.end_time) < new Date()))
}
onClick={() => handleEnterContest(item)}
icon={<EnterOutlined />}
type="primary"
>
Enter
</Button>
)}
/>
</div>
)
</Row>
</Card>
</List.Item>
)}
/>
</div>
);
}

export default Contests
export default Contests;