From 006e7e04a093d1c1afd2e2133a85c8f826b2a22a Mon Sep 17 00:00:00 2001
From: Abdelrahman Elkhateeb
<109158103+abdelrahman-elkhateeb@users.noreply.github.com>
Date: Sun, 11 Feb 2024 21:33:56 +0200
Subject: [PATCH] gpa calc styling
---
client/css/GPACalculator.css | 239 +++++++++++++++++++----------------
client/js/GPACalculator.js | 74 +++++++----
2 files changed, 183 insertions(+), 130 deletions(-)
diff --git a/client/css/GPACalculator.css b/client/css/GPACalculator.css
index 1819836..1d09c56 100644
--- a/client/css/GPACalculator.css
+++ b/client/css/GPACalculator.css
@@ -5,6 +5,13 @@
margin: 20px 0;
}
+@media (max-width: 767px) {
+ .gpaCalc .container form .subject-buttons {
+ display: flex;
+ flex-direction: column;
+ }
+}
+
.gpaCalc .container form .subject-buttons .sem {
display: flex;
flex-direction: column;
@@ -67,124 +74,142 @@
.gpaCalc .container form .subject-buttons .sem .selectAllWrap p,
.gpaCalc .container form .subject-buttons .sem .choiceWrap p {
-
margin: 0;
}
-
-
-
+.gpaCalc .container form .subject-buttons .sem .checkbox-wrapper input[type="checkbox"]:checked + label {
+ background-color: #07d410;
+ box-shadow: 0 var(--shadow) #92ff97;
+}
+
+.gpaCalc .container form .subject-buttons .sem .checkbox-wrapper input[type="checkbox"]:checked + label:before {
+ width: 0;
+ height: 0;
+}
+
+.gpaCalc
+ .container
+ form
+ .subject-buttons
+ .sem
+ .checkbox-wrapper
+ input[type="checkbox"]:checked
+ + label
+ .tickMark:before,
+.gpaCalc
+ .container
+ form
+ .subject-buttons
+ .sem
+ .checkbox-wrapper
+ input[type="checkbox"]:checked
+ + label
+ .tickMark:after {
+ transform: translate(0);
+ opacity: 1;
+}
diff --git a/client/js/GPACalculator.js b/client/js/GPACalculator.js
index fb0d500..cda2731 100644
--- a/client/js/GPACalculator.js
+++ b/client/js/GPACalculator.js
@@ -85,15 +85,23 @@ document.addEventListener("DOMContentLoaded", function () {
semesterHeader.textContent = `Semester ${subject.semester}`;
semesterDiv.appendChild(semesterHeader);
- // Add the div to the subjectButtonsContainer
- subjectButtonsContainer.appendChild(semesterDiv);
-
// Update the currentSemesterDiv
currentSemesterDiv = semesterDiv;
+ // Add the div to the subjectButtonsContainer
+ subjectButtonsContainer.appendChild(semesterDiv);
+
// Create a checkbox to select all subjects of this semester
const selectAllWrap = document.createElement("div");
selectAllWrap.classList.add("selectAllWrap");
+
+ const checkBoxWrapAll = document.createElement("div");
+ checkBoxWrapAll.classList.add("checkbox-wrapper");
+
+ const label = document.createElement("label");
+ label.setAttribute("for", `semester-${subject.semester}`);
+ const tickMarkAll = document.createElement("div");
+ tickMarkAll.classList.add("tickMark");
const input = document.createElement("input");
input.type = "checkbox";
input.name = `semester-${subject.semester}`;
@@ -101,7 +109,9 @@ document.addEventListener("DOMContentLoaded", function () {
input.value = subject.creditHours;
const pContent = document.createElement("p");
pContent.textContent = `Select All Semester ${subject.semester}`;
- selectAllWrap.appendChild(input);
+ checkBoxWrapAll.appendChild(input);
+ checkBoxWrapAll.appendChild(label);
+ selectAllWrap.appendChild(checkBoxWrapAll);
selectAllWrap.appendChild(pContent);
currentSemesterDiv.appendChild(selectAllWrap);
}
@@ -109,14 +119,30 @@ document.addEventListener("DOMContentLoaded", function () {
// Create a div to wrap each input and label
const choiceWrapDiv = document.createElement("div");
choiceWrapDiv.classList.add("choiceWrap");
-
- const input = document.createElement("input");
- input.type = "checkbox";
- input.name = subject.name + "-" + subject.semester;
- input.id = subject.semester + subject.name;
- input.value = subject.creditHours;
- const label = document.createElement("label");
- label.textContent = `${subject.name} (${subject.creditHours} credit hours)`;
+ //create checkbox wrap
+ const checkboxWrap = document.createElement("div");
+ checkboxWrap.classList.add("checkbox-wrapper");
+
+ const labelCheckBox = document.createElement("label");
+ const tickMark = document.createElement("div");
+ tickMark.classList.add("tickMark");
+
+ const checkboxSubject = document.createElement("input");
+ checkboxSubject.type = "checkbox";
+ checkboxSubject.name = subject.name + "-" + subject.semester;
+ checkboxSubject.id = subject.semester + subject.name;
+ checkboxSubject.value = subject.creditHours;
+
+ //apend the checkbox, label and tickmark inside the checkboxWrap
+ checkboxWrap.appendChild(checkboxSubject);
+ checkboxWrap.appendChild(labelCheckBox);
+ labelCheckBox.appendChild(tickMark);
+
+ // Set the 'for' attribute of the label to match the checkbox 'id'
+ labelCheckBox.setAttribute("for", subject.semester + subject.name);
+
+ const pSubject = document.createElement("p");
+ pSubject.textContent = `${subject.name} (${subject.creditHours} credit hours)`;
const gradeSelect = document.createElement("select");
gradeSelect.name = `${subject.name}-grade`;
@@ -128,15 +154,15 @@ document.addEventListener("DOMContentLoaded", function () {
}
// Append input, label, and gradeSelect to the choiceWrapDiv
- choiceWrapDiv.appendChild(input);
- choiceWrapDiv.appendChild(label);
+ choiceWrapDiv.appendChild(checkboxWrap);
+ choiceWrapDiv.appendChild(pSubject);
choiceWrapDiv.appendChild(gradeSelect);
// Hide grade option by default
gradeSelect.style.display = "none";
- input.addEventListener("change", function () {
+ checkboxSubject.addEventListener("change", function () {
// Make grade option visible when checkbox is checked
- if (input.checked) {
+ if (checkboxSubject.checked) {
gradeSelect.style.display = "block";
}
// Hide grade option when checkbox is unchecked
@@ -146,19 +172,21 @@ document.addEventListener("DOMContentLoaded", function () {
});
gradeSelect.addEventListener("change", function () {
- if (input.checked) {
- const selectedGrade = gradeSelect.value;
- const gradeValue = grades[selectedGrade];
+ let gradeValue;
+ let selectedGrade;
+ if (labelCheckBox.checked) {
+ selectedGrade = gradeSelect.value;
+ gradeValue = grades[selectedGrade];
gradesArray[subject.id - 1] = gradeValue; // Update grade in gradesArray
}
-
- console.log(gradesArray);
+ console.log(gradeValue, selectedGrade);
});
-
+ console.log(gradeSelect);
// Append the choiceWrapDiv to the currentSemesterDiv
currentSemesterDiv.appendChild(choiceWrapDiv);
});
+
// Select buttons that id starts with semester
const selectButtons = document.querySelectorAll('input[id^="semester-"]');
selectButtons.forEach((button) => {
@@ -200,4 +228,4 @@ document.addEventListener("DOMContentLoaded", function () {
alert(`GPA: ${result.toFixed(4)}`);
console.log("Grades Array:", gradesArray);
});
-});
+});
\ No newline at end of file