From 4f8553f6aa63ed55d4d93a72f55a78db120d5d93 Mon Sep 17 00:00:00 2001 From: Vincent Tiu Date: Tue, 12 Dec 2023 16:53:51 -0500 Subject: [PATCH] fix lesson levels insta load --- client/src/Teacher/TeacherDashboard.tsx | 34 ++++++++++++++++++-- client/src/components/LessonLevels.tsx | 42 +++++++++---------------- 2 files changed, 47 insertions(+), 29 deletions(-) diff --git a/client/src/Teacher/TeacherDashboard.tsx b/client/src/Teacher/TeacherDashboard.tsx index 448cb8f7..aa99ec64 100644 --- a/client/src/Teacher/TeacherDashboard.tsx +++ b/client/src/Teacher/TeacherDashboard.tsx @@ -9,7 +9,7 @@ import Typography from '@mui/material/Typography'; import { styled } from '@mui/system'; import { useNavigate, useParams } from 'react-router-dom'; // eslint-disable-next-line -import { Grid } from '@mui/material'; +import { CircularProgress, Grid } from '@mui/material'; import axios from 'axios'; import { useData } from '../util/api'; import { useAppSelector } from '../util/redux/hooks'; @@ -83,7 +83,10 @@ function StudentConcernsCard(props: any) { function SplitGrid() { const self = useAppSelector(selectUser); + + const [loading, setLoading] = useState(true); const [studentData, setStudentData] = useState([]); + const [levels, setLevels] = useState([]); useEffect(() => { const fetchData = async () => { @@ -92,6 +95,18 @@ function SplitGrid() { ); setStudentData(data); + + const l: { [key: number]: number } = {}; + data.forEach((student: any) => { + if (student.lessonNumber in l) { + l[student.lessonNumber] += 1; + } else { + l[student.lessonNumber] = 1; + } + }); + setLevels(l); + + setLoading(false); }; fetchData(); }, [self.email]); @@ -103,6 +118,21 @@ function SplitGrid() { (student: any) => student.attendanceFlag, ); + if (loading) { + return ( + + + + ); + } + return ( @@ -142,7 +172,7 @@ function SplitGrid() { - + ([]); - const [data, setData] = useState([]); - - useEffect(() => { - const fetchData = async () => { - const res = await axios.get( - `http://localhost:4000/api/teacher/lesson-levels/${id}`, - ); - - let max = 0; - Object.keys(res.data).forEach((level: string) => { - if (Number(level) > max) { - max = Number(level); - } - }); +interface ILessonLevelsProps { + levels: { + [key: number]: number; + }; +} - const l = Array.from(Array(max + 1).keys()); - setLabels(l); - const d = l.map((level) => Number(res.data[level] ?? 0)); - setData(d); - }; +function LessonLevels({ levels }: ILessonLevelsProps) { + let max = 0; + Object.keys(levels).forEach((level: string) => { + if (Number(level) > max) { + max = Number(level); + } + }); - fetchData(); - }, [id]); + const labels = Array.from(Array(max + 1).keys()); + const data = labels.map((level) => Number(levels[level] ?? 0)); + console.log(levels); return (