This commit is contained in:
2024-08-28 14:22:56 -06:00
parent 1051c4fb6e
commit 10afc745a9
5 changed files with 60 additions and 48 deletions

View File

@@ -1,9 +1,9 @@
"use client"
import { useLocalCoursesQuery } from "@/hooks/localCoursesHooks";
"use client";
import { useLocalCourseNamesQuery } from "@/hooks/localCoursesHooks";
import Link from "next/link";
export default function CourseList() {
const { data: courses } = useLocalCoursesQuery();
const { data: courses } = useLocalCourseNamesQuery();
return (
<div>
{courses.map((c) => (

View File

@@ -12,3 +12,12 @@ export async function PUT(
await fileStorageService.saveCourseAsync(updatedCourse, previousCourse);
return Response.json({});
}
export async function GET(
request: Request,
{ params: { courseName } }: { params: { courseName: string } }
) {
const courses = await fileStorageService.loadSavedCourses();
const course = courses.find((c) => c.settings.name === courseName);
return Response.json(course);
}

View File

@@ -1,3 +1,6 @@
import { fileStorageService } from "@/services/fileStorage/fileStorageService";
export async function GET() {
return Response.json([]);
const courses = await fileStorageService.loadSavedCourses();
return Response.json(courses);
}

View File

@@ -22,50 +22,53 @@ export default function CourseContextProvider({
DraggableItem | undefined
>();
const updateQuiz = (day: Date) => {
if (!itemBeingDragged) return;
const updatedQuiz: LocalQuiz = {
...(itemBeingDragged.item as LocalQuiz),
dueAt: dateToMarkdownString(day),
};
const localModule = course.modules.find((m) =>
m.quizzes.map((q) => q.name).includes(updatedQuiz.name)
);
if (!localModule)
console.log("could not find module for quiz ", updatedQuiz);
const updatedCourse: LocalCourse = {
...course,
modules: course.modules.map((m) =>
m.name !== localModule?.name
? m
: {
...m,
quizzes: m.quizzes.map((q) =>
q.name === updatedQuiz.name ? updatedQuiz : q
),
}
),
};
updateCourseMutation.mutate({
updatedCourse,
previousCourse: course,
});
};
return (
<CourseContext.Provider
value={{
localCourse: course,
startItemDrag: (d) => {
console.log("starting drag");
setItemBeingDragged(d);
},
endItemDrag: () => {
console.log("stopping drag");
setItemBeingDragged(undefined);
},
itemDrop: (day) => {
console.log("dropping");
if (itemBeingDragged && day) {
if (itemBeingDragged.type === "quiz") {
const updatedQuiz: LocalQuiz = {
...(itemBeingDragged.item as LocalQuiz),
dueAt: dateToMarkdownString(day),
};
const localModule = course.modules.find((m) =>
m.quizzes.map((q) => q.name).includes(updatedQuiz.name)
);
if (!localModule)
console.log("could not find module for quiz ", updatedQuiz);
const updatedCourse: LocalCourse = {
...course,
modules: course.modules.map((m) =>
m.name !== localModule?.name
? m
: {
...m,
quizzes: m.quizzes.map((q) =>
q.name === updatedQuiz.name ? updatedQuiz : q
),
}
),
};
updateCourseMutation.mutate({
updatedCourse,
previousCourse: course,
});
updateQuiz(day);
}
}
setItemBeingDragged(undefined);