Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
  • Loading branch information
pm3512 committed Jan 30, 2024
2 parents c46eb09 + 0871680 commit e866556
Show file tree
Hide file tree
Showing 7 changed files with 227 additions and 2 deletions.
2 changes: 1 addition & 1 deletion pages/teams.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -172,7 +172,7 @@ export default function ViewTeams(props: SSRDataAuth<TeamData>["props"]) {
{emptyMessage}
<table className={styles.tableData}>
<tbody>
{teams.map((team, idx) => (
{teams.sort((a, b) => +a.id - +b.id).map((team, idx) => (
<TeamTableEntry
team={team}
key={idx}
Expand Down
6 changes: 6 additions & 0 deletions src/_types/CheckIn.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
export interface CheckIn {
_id: string
name: string
points: string
checkinCount: string
}
13 changes: 13 additions & 0 deletions src/actions/checkin.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
import { DispatchActionType } from "enums/DispatchActionType"
import { RequestStatus } from "enums/RequestStatus"
import { RemoteDispatchAction } from "types/DispatchAction"

export const allCheckInItems = (): RemoteDispatchAction => ({
type: DispatchActionType.USER_GET_TEAM,
useAPI: true,
request: {
path: "/check-in",
method: "GET"
},
status: RequestStatus.PENDING
})
4 changes: 3 additions & 1 deletion src/actions/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import * as settings from "./settings"
import * as requests from "./requests"
import * as recruiters from "./recruiters"
import * as analytics from "./analytics"
import * as checkin from "./checkin"

export default {
auth,
Expand All @@ -17,5 +18,6 @@ export default {
settings,
requests,
recruiters,
analytics
analytics,
checkin
}
5 changes: 5 additions & 0 deletions src/components/admin/AdminDialog/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import AnalyticsTab from "../Analytics"
import ParticipantTable from "../ParticipantTable"
import RecruiterCreationForm from "../RecruiterCreationForm"
import SponsorCreationForm from "../SponsorCreationForm"
import CheckInTable from "../CheckInTable"
import styles from "./index.module.scss"

const AdminDialog = (): ReactElement => {
Expand Down Expand Up @@ -39,6 +40,7 @@ const AdminDialog = (): ReactElement => {
<Tab label="Recruiters" value="1" />
<Tab label="Sponsors" value="2" />
<Tab label="Analytics" value="3" />
<Tab label="Check-in Items" value="4" />
</TabList>
</Box>
<TabPanel value="0" className={styles.tabPanel}>
Expand All @@ -53,6 +55,9 @@ const AdminDialog = (): ReactElement => {
<TabPanel value="3" className={styles.tabPanel}>
<AnalyticsTab />
</TabPanel>
<TabPanel value="4" className={styles.tabPanel}>
<CheckInTable />
</TabPanel>
</TabContext>
</FloatingDiv>
)
Expand Down
42 changes: 42 additions & 0 deletions src/components/admin/CheckInTable/index.module.scss
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
@import "~/styles/variables.scss";
@import "~/styles/mixins.scss";

.dialog {
display: flex;
align-items: center;
width: 75%;
border-radius: 25px;
padding: 2rem;
margin: 0 auto;
flex-direction: column;
background-image: $dialog-container-gradient;
box-shadow: $dialog-container-box-shadow;
backdrop-filter: blur(4px);

max-height: 70%;
overflow: scroll;

@include down($breakpoint-md) {
width: 80%;
}

@include down($breakpoint-sm) {
width: 70%;
}
}

.dialogContent {
display: flex;
flex-direction: column;
align-items: center;
width: 100%;
}

.spinnerContainer {
display: flex;
justify-content: center;
}

.table {
width: 100%;
}
157 changes: 157 additions & 0 deletions src/components/admin/CheckInTable/index.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,157 @@
import {
CircularProgress,
Collapse,
Table,
TableBody,
TableCell,
TableContainer,
TableHead,
TableRow
} from "@mui/material"
import React, { ReactElement, useEffect, useMemo, useState } from "react"
import { useDispatch } from "react-redux"
import { Column, useTable } from "react-table"
import actions from "src/actions"
import styles from "./index.module.scss"
import { CheckIn } from "types/CheckIn"

const CheckInTable = (): ReactElement => {
const dispatch = useDispatch()
const [loading, setLoading] = useState(true)

const [checkIns, setCheckIns] = useState([])

useEffect(() => {
const getCheckIn = async () => {
setLoading(true)
try {
const { data } = await dispatch(actions.checkin.allCheckInItems())
data.sort((a: { startTime: number }, b: { startTime: number }) => {
return a.startTime > b.startTime
})
setCheckIns(data)
} catch (err) {
console.error(err)
}
setLoading(false)
}
getCheckIn()
}, [dispatch])

const columns: Column<CheckIn>[] = useMemo(
() => [
{
Header: "ID",
accessor: "_id"
},
{
Header: "Name",
accessor: "name"
},
{
Header: () => (
<div
style={{
textAlign: "center"
}}
>
Points
</div>
),
accessor: "points",
Cell: (row) => <div style={{ textAlign: "center" }}>{row.value}</div>
},
{
Header: () => (
<div
style={{
textAlign: "center"
}}
>
Check-In Count
</div>
),
accessor: "checkinCount",
Cell: (row) => <div style={{ textAlign: "center" }}>{row.value}</div>
}
],
[]
)
const { getTableProps, getTableBodyProps, headerGroups, rows, prepareRow } =
useTable<CheckIn>({
columns,
data: checkIns,
initialState: {
hiddenColumns: ["_id"]
}
})

return (
<>
<div className={styles.dialogContent}>
<Collapse in={loading}>
<div className={styles.spinnerContainer}>
<CircularProgress />
</div>
</Collapse>
<TableContainer>
<Table {...getTableProps()}>
<TableHead>
{
// Loop over the header rows
headerGroups.map((headerGroup, headerIdx) => (
// Apply the header row props
<TableRow
{...headerGroup.getHeaderGroupProps()}
key={headerIdx}
>
{
// Loop over the headers in each row
headerGroup.headers.map((column, cellIdx) => (
// Apply the header cell props
<TableCell {...column.getHeaderProps()} key={cellIdx}>
{
// Render the header
column.render("Header")
}
</TableCell>
))
}
</TableRow>
))
}
</TableHead>
{/* Apply the table body props */}
<TableBody {...getTableBodyProps()}>
{rows.map((row, rowIdx) => {
// Prepare the row for display
prepareRow(row)
return (
// Apply the row props
<TableRow {...row.getRowProps()} key={rowIdx}>
{
// Loop over the rows cells
row.cells.map((cell, cellIdx) => {
// Apply the cell props
return (
<TableCell {...cell.getCellProps()} key={cellIdx}>
{
// Render the cell contents
cell.render("Cell")
}
</TableCell>
)
})
}
</TableRow>
)
})}
</TableBody>
</Table>
</TableContainer>
</div>
</>
)
}

export default CheckInTable

0 comments on commit e866556

Please sign in to comment.