mirror of
https://github.com/alexmickelson/canvasManagement.git
synced 2026-03-26 07:38:33 -06:00
moving data management to lots of queries
This commit is contained in:
@@ -8,3 +8,19 @@ export const hydrateCourses = async (queryClient: QueryClient) => {
|
||||
queryFn: async () => await fileStorageService.getCourseNames(),
|
||||
});
|
||||
};
|
||||
|
||||
export const hydrateCourse = async (
|
||||
queryClient: QueryClient,
|
||||
courseName: string
|
||||
) => {
|
||||
const settings = await fileStorageService.getCourseSettings(courseName);
|
||||
const moduleNames = await fileStorageService.getModuleNames(courseName)
|
||||
await queryClient.prefetchQuery({
|
||||
queryKey: localCourseKeys.settings(courseName),
|
||||
queryFn: () => settings,
|
||||
});
|
||||
await queryClient.prefetchQuery({
|
||||
queryKey: localCourseKeys.moduleNames(courseName),
|
||||
queryFn: () => moduleNames,
|
||||
});
|
||||
};
|
||||
|
||||
@@ -1,8 +1,12 @@
|
||||
import { LocalAssignment } from "@/models/local/assignmnet/localAssignment";
|
||||
import { LocalCourse, LocalCourseSettings } from "@/models/local/localCourse";
|
||||
import { LocalModule } from "@/models/local/localModules";
|
||||
import { LocalCoursePage } from "@/models/local/page/localCoursePage";
|
||||
import { LocalQuiz } from "@/models/local/quiz/localQuiz";
|
||||
import {
|
||||
useMutation,
|
||||
useQueryClient,
|
||||
useSuspenseQueries,
|
||||
useSuspenseQuery,
|
||||
} from "@tanstack/react-query";
|
||||
import axios from "axios";
|
||||
@@ -18,12 +22,49 @@ export const localCourseKeys = {
|
||||
"modules",
|
||||
{ type: "names" } as const,
|
||||
] as const,
|
||||
moduleAssignmentNames: (courseName: string, moduleName: string) =>
|
||||
["course details", courseName, "modules", moduleName, "assignments"] as const,
|
||||
moduleQuizzeNames: (courseName: string, moduleName: string) =>
|
||||
["course details", courseName, "modules", moduleName, "quizzes"] as const,
|
||||
modulePageNames: (courseName: string, moduleName: string) =>
|
||||
["course details", courseName, "modules", moduleName, "pages"] as const,
|
||||
moduleAssignmentNames: (courseName: string, moduleName: string) =>
|
||||
[
|
||||
"course details",
|
||||
courseName,
|
||||
"modules",
|
||||
moduleName,
|
||||
"assignments",
|
||||
] as const,
|
||||
moduleQuizzeNames: (courseName: string, moduleName: string) =>
|
||||
["course details", courseName, "modules", moduleName, "quizzes"] as const,
|
||||
modulePageNames: (courseName: string, moduleName: string) =>
|
||||
["course details", courseName, "modules", moduleName, "pages"] as const,
|
||||
assignment: (
|
||||
courseName: string,
|
||||
moduleName: string,
|
||||
assignmentName: string
|
||||
) =>
|
||||
[
|
||||
"course details",
|
||||
courseName,
|
||||
"modules",
|
||||
moduleName,
|
||||
"assignments",
|
||||
assignmentName,
|
||||
] as const,
|
||||
quiz: (courseName: string, moduleName: string, quizName: string) =>
|
||||
[
|
||||
"course details",
|
||||
courseName,
|
||||
"modules",
|
||||
moduleName,
|
||||
"quizzes",
|
||||
quizName,
|
||||
] as const,
|
||||
page: (courseName: string, moduleName: string, pageName: string) =>
|
||||
[
|
||||
"course details",
|
||||
courseName,
|
||||
"modules",
|
||||
moduleName,
|
||||
"pages",
|
||||
pageName,
|
||||
] as const,
|
||||
};
|
||||
|
||||
export const useLocalCourseNamesQuery = () =>
|
||||
@@ -46,7 +87,7 @@ export const useLocalCourseSettingsQuery = (courseName: string) =>
|
||||
},
|
||||
});
|
||||
|
||||
export const useLocalCourseModuleNamesQuery = (courseName: string) =>
|
||||
export const useModuleNamesQuery = (courseName: string) =>
|
||||
useSuspenseQuery({
|
||||
queryKey: localCourseKeys.moduleNames(courseName),
|
||||
queryFn: async (): Promise<string[]> => {
|
||||
@@ -56,24 +97,107 @@ export const useLocalCourseModuleNamesQuery = (courseName: string) =>
|
||||
},
|
||||
});
|
||||
|
||||
|
||||
export const useUpdateCourseMutation = (courseName: string) => {
|
||||
const queryClient = useQueryClient();
|
||||
return useMutation({
|
||||
mutationFn: async (body: {
|
||||
updatedCourse: LocalCourse;
|
||||
previousCourse: LocalCourse;
|
||||
}) => {
|
||||
const url = `/api/courses/${courseName}`;
|
||||
await axios.put(url, body);
|
||||
},
|
||||
onSuccess: () => {
|
||||
queryClient.invalidateQueries({
|
||||
queryKey: localCourseKeys.settings(courseName),
|
||||
});
|
||||
},
|
||||
scope: {
|
||||
id: "all courses",
|
||||
export const useModuleAssignmentNamesQuery = (
|
||||
courseName: string,
|
||||
moduleName: string
|
||||
) =>
|
||||
useSuspenseQuery({
|
||||
queryKey: localCourseKeys.moduleAssignmentNames(courseName, moduleName),
|
||||
queryFn: async (): Promise<string[]> => {
|
||||
const url = `/api/courses/${courseName}/modules/${moduleName}/assignments`;
|
||||
const response = await axios.get(url);
|
||||
return response.data;
|
||||
},
|
||||
});
|
||||
};
|
||||
export const useModuleQuizNamesQuery = (
|
||||
courseName: string,
|
||||
moduleName: string
|
||||
) =>
|
||||
useSuspenseQuery({
|
||||
queryKey: localCourseKeys.moduleQuizzeNames(courseName, moduleName),
|
||||
queryFn: async (): Promise<string[]> => {
|
||||
const url = `/api/courses/${courseName}/modules/${moduleName}/quizzes`;
|
||||
const response = await axios.get(url);
|
||||
return response.data;
|
||||
},
|
||||
});
|
||||
|
||||
export const useModulePageNamesQuery = (
|
||||
courseName: string,
|
||||
moduleName: string
|
||||
) =>
|
||||
useSuspenseQuery({
|
||||
queryKey: localCourseKeys.modulePageNames(courseName, moduleName),
|
||||
queryFn: async (): Promise<string[]> => {
|
||||
const url = `/api/courses/${courseName}/modules/${moduleName}/pages`;
|
||||
const response = await axios.get(url);
|
||||
return response.data;
|
||||
},
|
||||
});
|
||||
|
||||
export const useAssignmentQuery = (
|
||||
courseName: string,
|
||||
moduleName: string,
|
||||
assignmentName: string
|
||||
) =>
|
||||
useSuspenseQuery({
|
||||
queryKey: localCourseKeys.assignment(
|
||||
courseName,
|
||||
moduleName,
|
||||
assignmentName
|
||||
),
|
||||
queryFn: async (): Promise<LocalAssignment> => {
|
||||
const url = `/api/courses/${courseName}/modules/${moduleName}/assignments/${assignmentName}`;
|
||||
const response = await axios.get(url);
|
||||
return response.data;
|
||||
},
|
||||
});
|
||||
|
||||
export const useQuizQuery = (
|
||||
courseName: string,
|
||||
moduleName: string,
|
||||
quizName: string
|
||||
) =>
|
||||
useSuspenseQuery({
|
||||
queryKey: localCourseKeys.quiz(courseName, moduleName, quizName),
|
||||
queryFn: async (): Promise<LocalQuiz> => {
|
||||
const url = `/api/courses/${courseName}/modules/${moduleName}/quizzes/${quizName}`;
|
||||
const response = await axios.get(url);
|
||||
return response.data;
|
||||
},
|
||||
});
|
||||
|
||||
export const usePageQuery = (
|
||||
courseName: string,
|
||||
moduleName: string,
|
||||
pageName: string
|
||||
) =>
|
||||
useSuspenseQuery({
|
||||
queryKey: localCourseKeys.quiz(courseName, moduleName, pageName),
|
||||
queryFn: async (): Promise<LocalCoursePage> => {
|
||||
const url = `/api/courses/${courseName}/modules/${moduleName}/pages/${pageName}`;
|
||||
const response = await axios.get(url);
|
||||
return response.data;
|
||||
},
|
||||
});
|
||||
|
||||
// export const useUpdateCourseMutation = (courseName: string) => {
|
||||
// const queryClient = useQueryClient();
|
||||
// return useMutation({
|
||||
// mutationFn: async (body: {
|
||||
// updatedCourse: LocalCourse;
|
||||
// previousCourse: LocalCourse;
|
||||
// }) => {
|
||||
// const url = `/api/courses/${courseName}`;
|
||||
// await axios.put(url, body);
|
||||
// },
|
||||
// onSuccess: () => {
|
||||
// queryClient.invalidateQueries({
|
||||
// queryKey: localCourseKeys.settings(courseName),
|
||||
// });
|
||||
// },
|
||||
// scope: {
|
||||
// id: "all courses",
|
||||
// },
|
||||
// });
|
||||
// };
|
||||
|
||||
Reference in New Issue
Block a user