We got this
This commit is contained in:
@@ -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>
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
16
docs/main.js
16
docs/main.js
@@ -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 = {
|
||||||
|
|||||||
Reference in New Issue
Block a user