We got this

This commit is contained in:
2023-05-01 03:27:51 -05:00
parent 6c8cd20b06
commit c99770b64b
3 changed files with 39 additions and 31 deletions

View File

@@ -14,7 +14,7 @@
<meta charset='utf-8'> <meta charset='utf-8'>
<meta http-equiv='X-UA-Compatible' content='IE=edge'> <meta http-equiv='X-UA-Compatible' content='IE=edge'>
<title>UT Grade Viewer</title> <title>UT Grade Viewer</title>
<link rel="icon" href="https://derec4.github.io/ut-grade-distribution-viewer/data/icon.png"> <link rel="icon" href="https://github.com/DereC4/ut-grade-distribution-viewer/blob/master/data/icon.png?raw=true">
<meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel='stylesheet' type='text/css' media='screen' href='main.css'> <link rel='stylesheet' type='text/css' media='screen' href='main.css'>
<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.9.4/Chart.js"> <script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.9.4/Chart.js">
@@ -48,8 +48,10 @@
<input type="text" id="courseField" name="fname" required><br><br> <input type="text" id="courseField" name="fname" required><br><br>
<label for="courseNum">Course Number (Ex: "307"):</label> <label for="courseNum">Course Number (Ex: "307"):</label>
<input type="text" id="courseNum" name="fname" required><br><br> <input type="text" id="courseNum" name="fname" required><br><br>
<label for="courseName">Course Name (Optional, useful if classes have the same number like UGS 303):</label> <label for="courseName">Course Name (Optional, useful if classes have the same number Ex: UGS 303):</label>
<input type="text" id="courseName" name="fname"><br><br> <input type="text" id="courseName" name="fname"><br><br>
<label for="sectionNum">Section Number (Optional, can be used alone)</label>
<input type="text" id="sectionNum" name="fname" required><br><br>
<!-- <label for="courseInstructor">Instructor (Optional):</label> <!-- <label for="courseInstructor">Instructor (Optional):</label>
<input type="text" id="courseInstructor" name="fname"><br><br> --> <input type="text" id="courseInstructor" name="fname"><br><br> -->
<button type="button" id="subBut">Submit</button><br><br> <button type="button" id="subBut">Submit</button><br><br>

View File

@@ -54,7 +54,7 @@ footer {
border: 3px solid #f1f1f1; border: 3px solid #f1f1f1;
grid-column: 1; grid-column: 1;
grid-row: 2; grid-row: 2;
font-weight: 600; font-weight: 400;
width: auto; width: auto;
height: auto; height: auto;
margin: 0 auto; margin: 0 auto;

View File

@@ -14,11 +14,13 @@ const gradeLabels = ["A", "A-", "B+", "B", "B-", "C+", "C", "C-", "D+", "D", "D-
Parse the input form and class data Parse the input form and class data
*/ */
async function parseName() { async function parseName() {
let fiveDigit = document.getElementById('sectionNum').value;
let className = document.getElementById('courseName').value.toUpperCase(); let className = document.getElementById('courseName').value.toUpperCase();
let classNum = document.getElementById('courseNum').value; let classNum = document.getElementById('courseNum').value;
let department = document.getElementById('courseField').value.trim().toUpperCase(); let department = document.getElementById('courseField').value.trim().toUpperCase();
let semester = document.getElementById('semester').value; let semester = document.getElementById('semester').value;
let departments = ''; let departments = '';
if(!fiveDigit) {
await fetch('https://derec4.github.io/ut-grade-data/2022prefixes.json') await fetch('https://derec4.github.io/ut-grade-data/2022prefixes.json')
.then(res => res.json()) .then(res => res.json())
.then(data => { departments = data; }); .then(data => { departments = data; });
@@ -35,13 +37,14 @@ async function parseName() {
return; return;
} }
console.log(department, classNum.toString(), className.trim(), semester); console.log(department, classNum.toString(), className.trim(), semester);
await PapaParse(department, classNum.toString(), className.trim(), semester); }
await PapaParse(department, classNum.toString(), className.trim(), semester, fiveDigit);
} }
/* /*
Fetch the necessary database depending on semester and filter based on the input data Fetch the necessary database depending on semester and filter based on the input data
*/ */
async function PapaParse(department, num, name, sem) { async function PapaParse(department, num, name, sem, unique) {
let cData = ''; let cData = '';
let url = ''; let url = '';
switch (sem) { switch (sem) {
@@ -65,8 +68,11 @@ async function PapaParse(department, num, name, sem) {
await fetch(url) await fetch(url)
.then(res => res.json()) .then(res => res.json())
.then(data => { cData = data; }); .then(data => { cData = data; });
let selectedClass = '';
let selectedClass = cData.filter(cData => cData["Course Prefix"].includes(department)) if(unique) {
selectedClass = cData.filter(cData => cData['Section Number'] == unique);
} else {
selectedClass = cData.filter(cData => cData["Course Prefix"].includes(department))
.filter(cData => cData["Course Number"] == num.toString().toUpperCase()) .filter(cData => cData["Course Number"] == num.toString().toUpperCase())
.filter(cData => cData["Course Title"].includes(name)); .filter(cData => cData["Course Title"].includes(name));
if(selectedClass.length == 0) { if(selectedClass.length == 0) {
@@ -75,12 +81,12 @@ async function PapaParse(department, num, name, sem) {
selectedClass = cData.filter(cData => cData["Course Prefix"].includes(department)) selectedClass = cData.filter(cData => cData["Course Prefix"].includes(department))
.filter(cData => cData["Course Number"] == num.toString().toUpperCase()); .filter(cData => cData["Course Number"] == num.toString().toUpperCase());
} }
}
if(selectedClass.length == 0) { if(selectedClass.length == 0) {
// Still can't find anything? Just exit without making a chart and alert that nothing could be found // Still can't find anything? Just exit without making a chart and alert that nothing could be found
alert("No data found. Try again :("); alert("No data found. Try again :(");
return; return;
} }
console.log(selectedClass); console.log(selectedClass);
let gradeDist = { let gradeDist = {