gonito-frontend/src/components/elements/MiniChallenge.js

98 lines
2.7 KiB
JavaScript
Raw Normal View History

2022-07-07 15:45:29 +02:00
import React from "react";
import {Container, FlexColumn, FlexRow, Grid} from "../../utils/containers";
2022-07-07 15:45:29 +02:00
import {Body, H3} from "../../utils/fonts";
import styled from "styled-components";
import IconLabel from "./IconLabel";
import {Link} from "react-router-dom";
import {CHALLENGE_PAGE} from "../../utils/globals";
2022-07-07 15:45:29 +02:00
const ChallengeStyle = styled(FlexColumn)`
padding: 12px;
border: 1px solid ${({theme}) => theme.colors.dark05};
cursor: pointer;
2022-07-08 09:36:10 +02:00
transition: transform 0.3s ease-in-out;
position: relative;
max-width: 420px;
2022-07-07 15:45:29 +02:00
p {
width: 80%;
}
* {
cursor: pointer;
}
&:hover {
2022-07-08 09:36:10 +02:00
transform: scale(1.05);
2022-07-07 15:45:29 +02:00
}
a {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}
2022-07-07 15:45:29 +02:00
`;
const Line = styled(Container)`
height: 1px;
width: 85%;
2022-07-07 15:45:29 +02:00
background-color: ${({theme}) => theme.colors.dark05};
margin-bottom: 14px;
`;
const IconsGrid = styled(Grid)`
width: 100%;
grid-gap: 14px;
grid-template-columns: 1fr 1fr;
grid-template-rows: 1fr 1fr;
@media (min-width: 500px) {
grid-template-columns: 1fr 1fr 1fr;
}
`;
const MiniChallenge = (props) => {
const renderDescription = (description) => {
if (description.length <= 200)
return description;
return `${description.slice(0, 100)}...`
}
2022-07-07 15:45:29 +02:00
return (
<ChallengeStyle as='article' alignmentX='flex-start'>
<FlexRow margin='0 0 14px 0' gap='12px' width='100%' alignmentX='space-between'>
<H3 as='h3' width='85%'>
2022-07-07 15:45:29 +02:00
{props.title}
</H3>
<IconLabel type={props.type} size='30px'/>
2022-07-07 15:45:29 +02:00
</FlexRow>
<Line/>
2022-07-07 15:45:29 +02:00
<Body as='p' margin='0 0 14px 0'>
{props.description ? renderDescription(props.description) : 'xxx'}
2022-07-07 15:45:29 +02:00
</Body>
<IconsGrid>
<IconLabel size='24px' gap='8px' type='metric'>
{props.metric ? props.metric : 'xxx'}
2022-07-07 15:45:29 +02:00
</IconLabel>
<IconLabel size='24px' gap='8px' type='bestScore'>
{props.bestScore ? props.bestScore : 'xxx'}
2022-07-07 15:45:29 +02:00
</IconLabel>
<IconLabel size='24px' gap='8px' type='deadline'>
{props.deadline ? props.deadline.slice(0, 10) : 'xxx'}
2022-07-07 15:45:29 +02:00
</IconLabel>
<IconLabel size='24px' gap='8px' type='baseline'>
{props.baseline ? props.baseline : 'xxx'}
2022-07-07 15:45:29 +02:00
</IconLabel>
{props.prize ? <IconLabel size='24px' gap='8px' type='prize'>
{props.prize}
</IconLabel> : ''}
2022-07-07 15:45:29 +02:00
</IconsGrid>
<Container as={Link} to={`${CHALLENGE_PAGE}/${props.name}`}/>
2022-07-07 15:45:29 +02:00
</ChallengeStyle>
);
}
export default MiniChallenge;