Skip to content

Commit

Permalink
completed student
Browse files Browse the repository at this point in the history
  • Loading branch information
TanishqMehrunkarIIPSDAVV committed Oct 7, 2024
1 parent 654b156 commit 6497165
Show file tree
Hide file tree
Showing 4 changed files with 249 additions and 5 deletions.
2 changes: 2 additions & 0 deletions src/App.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ import EditQuestion from './edit_question/EditQuestion';
import Profile from './Profile/profile';
import Body from './Body/Body';
import CompletedPaperDashboard from './CompletedPaperDashboard/CompletedPaperDashboard';
import CompletedPaperStudentDashboard from './CompletedPaperStudentDashboard/CompletedPaperStudentDashboard';



Expand Down Expand Up @@ -82,6 +83,7 @@ const App = () => {
<Route path='/profile' element={<Profile/>}/>
<Route path="/preview/:questionId" element={<Body/>}/>
<Route path="/completed_papers" element={<CompletedPaperDashboard />}/>
<Route path='/completed_papers_student/:paperId' element={<CompletedPaperStudentDashboard />}/>
</>
)}

Expand Down
22 changes: 17 additions & 5 deletions src/CompletedPaperDashboard/CompletedPaperDashboard.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,13 +6,20 @@ import axios from "axios";
import Nothing from "../Assets/nothing.svg";
import Navbar from "../Navbar/Navbar";
import Skeleton from "../Skeleton/Skeleton";
import { GoDotFill } from "react-icons/go";
import { useNavigate } from "react-router-dom";
// import AlertModal from "../AlertModal/AlertModal";

const CompletedPaperDashboard = () => {
// const navigate = useNavigate();
const navigate = useNavigate();
const [completedPapers, setCompletedPapers] = useState([]);
// const [hoveredItem, setHoveredItem] = useState(null);
const [loading, setLoading] = useState(true);
const evaluations=[
"Evaluated",
"Not-Evaluated",
"Evaluation-in-Progress",
];

const teacherId = localStorage.getItem("teacherId");
// const [reload, setReload] = useState(false);
Expand Down Expand Up @@ -59,9 +66,10 @@ const getFormattedDateTime = (date, time) => {
fetchCompletedPapers();
}, [teacherId]);

// const handleCardClick = (paperId) => {
// navigate(`/completed_questions/${paperId}`);
// };
const handleCardClick = (paperId) => {
// navigate(`/completed_questions/${paperId}`);
navigate(`/completed_papers_student/${paperId}`);
};

return (
<>
Expand All @@ -84,7 +92,7 @@ const getFormattedDateTime = (date, time) => {
<div
className="papers_table"
key={index}
// onClick={() => handleCardClick(paper._id)}
onClick={() => handleCardClick(paper._id)}
// onMouseEnter={() => setHoveredItem(paper._id)}
// onMouseLeave={() => setHoveredItem(null)}
>
Expand All @@ -93,6 +101,10 @@ const getFormattedDateTime = (date, time) => {
Completed on: {getFormattedDateTime(paper.endTime, paper.time)}
</div>
<div className="table-data">
<div className={`evaluation ${evaluations[0]}`}>
<GoDotFill />
<div>{evaluations[0]}</div>
</div>
<div className="classhead">
{paper.className} {paper.semester}
</div>
Expand Down
129 changes: 129 additions & 0 deletions src/CompletedPaperStudentDashboard/CompletedPaperStudentDashboard.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,129 @@
import React, { useState, useEffect } from "react";
import "../papers/papers.css";
import Nothing from "../Assets/nothing.svg";
import Navbar from "../Navbar/Navbar";
import Skeleton from "../Skeleton/Skeleton";
import axios from "axios";
import { useParams } from "react-router-dom";
import { GoDotFill } from "react-icons/go";
import { FaCheck } from "react-icons/fa";
import { ImCross } from "react-icons/im";
import image from "../Assets/profile_photo.png";

const CompletedPaperStudentDashboard = () => {
const [students, setStudents] = useState([]);
const [loading, setLoading] = useState(true);
const { paperId } = useParams();
const evaluations = ["Evaluated", "Not-Evaluated", "Evaluation-in-Progress"];
const attemptions = ["Attempted", "Not-Attempted"];

useEffect(() => {
axios
.post("http://localhost:5000/student/getStudentByPaperId", {
paperId,
})
.then((res) => {
setStudents(res.data.students);
})
.catch((err) => {
console.log(err);
})
.finally(() => {
setTimeout(() => {
setLoading(false);
}, 1000);
});
}, []);
return (
<>
<Navbar />
<div className="exam-list-container">
{loading ? (
<Skeleton exams={students} />
) : students.length > 0 ? (
<>
<div className="header">
<h2>Students:</h2>
</div>
<div className="exam-table">
{students.map((student, index) => (
<div
className="papers_table"
key={index}
// onClick={() => handleCardClick(student._id)}
// onMouseEnter={() => setHoveredItem(paper._id)}
// onMouseLeave={() => setHoveredItem(null)}
>
{/* Since delete and move features are removed, no buttons are shown */}
{/* <div className="scheduled">
Completed on: {getFormattedDateTime(paper.endTime, paper.time)}
</div> */}
<div className="table-data">
<div className="evaluation-attemption">
<div className={`evaluation ${evaluations[0]}`}>
<GoDotFill />
<div>{evaluations[0]}</div>
</div>
<div className={`attemption ${attemptions[0]}`}>
{attemptions[0] === "Attempted" ? (
<>
<FaCheck />
<div>Attempted</div>
</>
) : (
<>
{attemptions[0] === "Not-Attempted" ? (
<>
<ImCross />
<div>Not Attempted</div>
</>
) : (
<></>
)}
</>
)}
</div>
</div>
<div className="student-image-name">
<div className="student-image">
<img src={image} alt="Image"/>
</div>
<div className="student-name">
<div className="classhead">{student.fullName}</div>
<div className="subname">Email: &nbsp;{student.email}</div>
<div className="subname">{student.rollNumber}</div>
</div>
</div>
{/* <div className="subname">
{student.subject} ({student.subjectCode})
</div>
<div>
Duration: {student.duration.hours} hours{" "}
{student.duration.minutes} mins
</div>
<div>Marks: {student.marks}</div> */}
</div>
</div>
))}
</div>
</>
) : (
<div className="no-questions-container">
<center>
<img alt="Nothing" src={Nothing} className="nothing" />
<h2>No Students Found</h2>
</center>
</div>
)}
</div>
{/* <AlertModal
isOpen={modalIsOpen}
onClose={() => setModalIsOpen(false)}
message={modalMessage}
iserror={isError}
/> */}
</>
);
};

export default CompletedPaperStudentDashboard;
101 changes: 101 additions & 0 deletions src/papers/papers.css
Original file line number Diff line number Diff line change
Expand Up @@ -181,4 +181,105 @@

.readyDasboardwarning{
color: red;
}

/*----------------Completed Papers------------ */

.evaluation
{
font-size: 18px;
display: flex;
gap: 5px;
align-items: center;
background-color: #282828;
border-radius: 3px;
}
.Evaluated
{
color: green;
width: 110px;
}
.Not-Evaluated
{
color: red;
width: 145px;
}
.Evaluation-in-Progress
{
color: yellow;
width: 210px;
}
.evaluation-attemption
{
display: flex;
justify-content: space-between;
align-items: center;
}
.attemption
{
display: flex;
gap: 5px;
align-items: center;
background-color: #282828;
border-radius: 3px;
height: 30px;
justify-content: center;
}
.Attempted
{
width: 110px;
color: green;
}
.Not-Attempted
{
width: 140px;
color: red;
}
.student-image-name
{
display: flex;
gap: 50px;
align-items: center;
margin-top: 10px;
}
.student-image {
width: 100px;
height: 100px;
}

.student-image img {
width: 100%;
height: 100%;
object-fit: cover;
}
.student-image img
{
width: 100%;
height: 100%;
}
.student-name
{
margin-top: -45px;
}
@media screen and (max-width: 768px) {
.student-image {
width: 80px;
height: 80px;
}
.student-image-name
{
gap: 10px;
}
.student-name
{
margin-top: -25px;
}
}

/* Media Query for extra small screens */
@media screen and (max-width: 480px) {
.student-image {
width: 60px;
height: 60px;
}
}

0 comments on commit 6497165

Please sign in to comment.