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