diff --git a/webclient/src/Classes.js b/webclient/src/Classes.js
index 96ae0bc..d4c01be 100644
--- a/webclient/src/Classes.js
+++ b/webclient/src/Classes.js
@@ -101,6 +101,7 @@ function NewClassTableCourse(props) {
const {course, classes, token, user, refreshUser} = props;
const [error, setError] = useState(false);
const [loading, setLoading] = useState(false);
+ const [interested, setInterested] = useState(course.num_interested || 0);
const handleInterest = () => {
if (loading) return;
@@ -110,6 +111,7 @@ function NewClassTableCourse(props) {
.then(res => {
setError(false);
refreshUser();
+ setInterested(interested+1);
})
.catch(err => {
console.log(err);
@@ -139,14 +141,19 @@ function NewClassTableCourse(props) {
{user &&
{user.interests.filter(x => !x.satisfied_by).map(x => x.course).includes(course.id) ?
- 'Interested ✅'
+
:
}
@@ -206,7 +213,7 @@ function NewClassTable(props) {
let sortedClasses = [];
let seenCourseIds = [];
- if (classes.length) {
+ if (classes.length && courses.length) {
for (const clazz of classes) {
const course_data = clazz.course_data;
const course = sortedClasses.find(x => x?.course?.id === course_data?.id);
@@ -215,7 +222,7 @@ function NewClassTable(props) {
course.classes.push(clazz);
} else {
sortedClasses.push({
- course: course_data,
+ course: courses.find(x => x.id === course_data.id),
classes: [clazz],
});
seenCourseIds.push(
diff --git a/webclient/src/light.css b/webclient/src/light.css
index 689ba64..be09837 100644
--- a/webclient/src/light.css
+++ b/webclient/src/light.css
@@ -157,6 +157,11 @@ body {
margin-left: auto;
}
+.interest .ui.button {
+ padding-left: 0.5rem;
+ padding-right: 0.5rem;
+}
+
.ui.tag.label {
padding-left: 1rem;
padding-right: 0.5rem;