aboutsummaryrefslogtreecommitdiff
path: root/src/components/EventCard/EventCard.tsx
blob: bd09c450baee0d6dc6132dffa7a3ebe71e14d274 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
import React from 'react';
import {
  Card,
  CardHeader,
  CardContent,
  CardActions,
  Button
} from '@material-ui/core';
import { Event } from '../../types';
import { patch } from '../../requests';

interface PropTypes {
  event: Event;
  mutate: () => void;
}

const EventCard: React.FC<PropTypes> = ({ event, mutate }) => {
  const {
    data: {
      name,
      date,
      participants,
      conferenceId,
      attendanceId
    }
  } = event;

  const handleJoin = () => {
    // TODO: add your username to participants list
    const update = { data: { participants: [...participants, Math.random()] }}
    return patch(`/events/${event._id}`, update).then(() => mutate());
  };

  return (
    <Card variant="outlined">
      <CardHeader title={name || `Event #${event._id.slice(-4)}`} subheader={date}  />
      <CardContent>
        {conferenceId && <div> ConferenceID: {conferenceId} </div>}
        {attendanceId && <div> AttendanceID: {attendanceId} </div>}
        <div>
          Participants ({participants?.length || 0} / 3)
          <ul>
            {participants?.map(username => (
              <li> {username} </li>
            ))}
          </ul>
        </div>
      </CardContent>
      {(participants?.length || 0) < 3 && (
        <CardActions>
          <Button
            onClick={handleJoin}
            variant="contained"
            color="primary"
            size="large"
          >
            Join
          </Button>
        </CardActions>
      )}
    </Card>
  );
};

export default EventCard;