mirror of
https://github.com/alexmickelson/canvasManagement.git
synced 2026-03-25 23:28:33 -06:00
updates
This commit is contained in:
@@ -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) => (
|
||||
|
||||
@@ -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);
|
||||
}
|
||||
|
||||
@@ -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);
|
||||
}
|
||||
|
||||
@@ -22,22 +22,9 @@ export default function CourseContextProvider({
|
||||
DraggableItem | undefined
|
||||
>();
|
||||
|
||||
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 updateQuiz = (day: Date) => {
|
||||
if (!itemBeingDragged) return;
|
||||
|
||||
const updatedQuiz: LocalQuiz = {
|
||||
...(itemBeingDragged.item as LocalQuiz),
|
||||
dueAt: dateToMarkdownString(day),
|
||||
@@ -66,6 +53,22 @@ export default function CourseContextProvider({
|
||||
updatedCourse,
|
||||
previousCourse: course,
|
||||
});
|
||||
};
|
||||
return (
|
||||
<CourseContext.Provider
|
||||
value={{
|
||||
localCourse: course,
|
||||
startItemDrag: (d) => {
|
||||
setItemBeingDragged(d);
|
||||
},
|
||||
endItemDrag: () => {
|
||||
setItemBeingDragged(undefined);
|
||||
},
|
||||
itemDrop: (day) => {
|
||||
console.log("dropping");
|
||||
if (itemBeingDragged && day) {
|
||||
if (itemBeingDragged.type === "quiz") {
|
||||
updateQuiz(day);
|
||||
}
|
||||
}
|
||||
setItemBeingDragged(undefined);
|
||||
|
||||
@@ -1,6 +1,5 @@
|
||||
import { LocalCourse } from "@/models/local/localCourse";
|
||||
import {
|
||||
dataTagSymbol,
|
||||
useMutation,
|
||||
useQueryClient,
|
||||
useSuspenseQuery,
|
||||
@@ -9,10 +8,10 @@ import axios from "axios";
|
||||
|
||||
export const localCourseKeys = {
|
||||
allCourses: ["all courses"] as const,
|
||||
courseDetail: (courseName: string) => ["all courses", courseName] as const,
|
||||
courseDetail: (courseName: string) => ["course details", courseName] as const,
|
||||
};
|
||||
|
||||
export const useLocalCoursesQuery = () =>
|
||||
export const useLocalCourseNamesQuery = () =>
|
||||
useSuspenseQuery({
|
||||
queryKey: localCourseKeys.allCourses,
|
||||
queryFn: async (): Promise<LocalCourse[]> => {
|
||||
@@ -20,20 +19,16 @@ export const useLocalCoursesQuery = () =>
|
||||
const response = await axios.get(url);
|
||||
return response.data;
|
||||
},
|
||||
select: (courses) => courses.map((c) => c.settings.name),
|
||||
});
|
||||
|
||||
export const useLocalCourseDetailsQuery = (courseName: string) => {
|
||||
const { data: courses } = useLocalCoursesQuery();
|
||||
return useSuspenseQuery({
|
||||
queryKey: localCourseKeys.courseDetail(courseName),
|
||||
queryFn: () => {
|
||||
const course = courses.find((c) => c.settings.name === courseName);
|
||||
if (!course) {
|
||||
console.log(courses);
|
||||
console.log(courseName);
|
||||
throw Error(`Could not find course with name ${courseName}`);
|
||||
}
|
||||
return course;
|
||||
queryFn: async (): Promise<LocalCourse> => {
|
||||
const url = `/api/courses/${courseName}`;
|
||||
const response = await axios.get(url);
|
||||
return response.data;
|
||||
},
|
||||
});
|
||||
};
|
||||
@@ -49,10 +44,12 @@ export const useUpdateCourseMutation = (courseName: string) => {
|
||||
await axios.put(url, body);
|
||||
},
|
||||
onSuccess: () => {
|
||||
queryClient.invalidateQueries({ queryKey: localCourseKeys.allCourses }); //optimize?
|
||||
queryClient.invalidateQueries({
|
||||
queryKey: localCourseKeys.courseDetail(courseName),
|
||||
});
|
||||
},
|
||||
scope: {
|
||||
id: "update course",
|
||||
id: "all courses",
|
||||
},
|
||||
});
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user