more consolodation

This commit is contained in:
2024-09-27 12:17:38 -06:00
parent 3a69222ddc
commit 150de48335
5 changed files with 57 additions and 148 deletions

View File

@@ -73,7 +73,7 @@ export default function NewItemForm({
} }
if (type === "Assignment") { if (type === "Assignment") {
createAssignment.mutate({ createAssignment.mutate({
assignment: { item: {
name, name,
description: "", description: "",
dueAt, dueAt,
@@ -85,11 +85,11 @@ export default function NewItemForm({
rubric: [], rubric: [],
}, },
moduleName: moduleName, moduleName: moduleName,
assignmentName: name, itemName: name,
}); });
} else if (type === "Quiz") { } else if (type === "Quiz") {
createQuiz.mutate({ createQuiz.mutate({
quiz: { item: {
name, name,
description: "", description: "",
dueAt, dueAt,
@@ -100,17 +100,17 @@ export default function NewItemForm({
questions: [], questions: [],
}, },
moduleName: moduleName, moduleName: moduleName,
quizName: name, itemName: name,
}); });
} else if (type === "Page") { } else if (type === "Page") {
createPage.mutate({ createPage.mutate({
page: { item: {
name, name,
text: "", text: "",
dueAt, dueAt,
}, },
moduleName: moduleName, moduleName: moduleName,
pageName: name, itemName: name,
}); });
} }
onCreate(); onCreate();

View File

@@ -12,6 +12,7 @@ import { axiosClient } from "@/services/axiosUtils";
import { import {
getAllItemsQueryConfig, getAllItemsQueryConfig,
getItemQueryConfig, getItemQueryConfig,
useCreateItemMutation,
useItemQuery, useItemQuery,
useItemsQueries, useItemsQueries,
useUpdateItemMutation, useUpdateItemMutation,
@@ -39,56 +40,8 @@ export const useAssignmentsQueries = (moduleName: string) =>
export const useUpdateAssignmentMutation = () => export const useUpdateAssignmentMutation = () =>
useUpdateItemMutation("Assignment"); useUpdateItemMutation("Assignment");
export const useCreateAssignmentMutation = () => { export const useCreateAssignmentMutation = () =>
const { courseName } = useCourseContext(); useCreateItemMutation("Assignment");
const queryClient = useQueryClient();
return useMutation({
mutationFn: async ({
assignment,
moduleName,
assignmentName,
}: {
assignment: LocalAssignment;
moduleName: string;
assignmentName: string;
}) => {
queryClient.setQueryData(
localCourseKeys.itemOfType(
courseName,
moduleName,
assignmentName,
"Assignment"
),
assignment
);
const url =
"/api/courses/" +
encodeURIComponent(courseName) +
"/modules/" +
encodeURIComponent(moduleName) +
"/assignments/" +
encodeURIComponent(assignmentName);
await axiosClient.post(url, assignment);
},
onSuccess: async (_, { moduleName, assignmentName }) => {
await queryClient.invalidateQueries({
queryKey: localCourseKeys.allItemsOfType(
courseName,
moduleName,
"Assignment"
),
});
await queryClient.invalidateQueries({
queryKey: localCourseKeys.itemOfType(
courseName,
moduleName,
assignmentName,
"Assignment"
),
});
},
});
};
export const useDeleteAssignmentMutation = () => { export const useDeleteAssignmentMutation = () => {
const { courseName } = useCourseContext(); const { courseName } = useCourseContext();

View File

@@ -175,3 +175,47 @@ export const useUpdateItemMutation = <T extends CourseItemType>(type: T) => {
}, },
}); });
}; };
export const useCreateItemMutation = <T extends CourseItemType>(type: T) => {
const { courseName } = useCourseContext();
const queryClient = useQueryClient();
return useMutation({
mutationFn: async ({
item,
moduleName,
itemName,
}: {
item: CourseItemReturnType<T>;
moduleName: string;
itemName: string;
}) => {
queryClient.setQueryData(
localCourseKeys.itemOfType(courseName, moduleName, itemName, type),
item
);
const url =
"/api/courses/" +
encodeURIComponent(courseName) +
"/modules/" +
encodeURIComponent(moduleName) +
"/" +
typeToFolder[type] +
"/" +
encodeURIComponent(itemName);
await axiosClient.post(url, item);
},
onSuccess: async (_, { moduleName, itemName: assignmentName }) => {
await queryClient.invalidateQueries({
queryKey: localCourseKeys.allItemsOfType(courseName, moduleName, type),
});
await queryClient.invalidateQueries({
queryKey: localCourseKeys.itemOfType(
courseName,
moduleName,
assignmentName,
type
),
});
},
});
};

View File

@@ -7,6 +7,7 @@ import { axiosClient } from "@/services/axiosUtils";
import { import {
getAllItemsQueryConfig, getAllItemsQueryConfig,
getItemQueryConfig, getItemQueryConfig,
useCreateItemMutation,
useItemQuery, useItemQuery,
useItemsQueries, useItemsQueries,
useUpdateItemMutation, useUpdateItemMutation,
@@ -32,52 +33,7 @@ export const usePagesQueries = (moduleName: string) =>
export const useUpdatePageMutation = () => useUpdateItemMutation("Page"); export const useUpdatePageMutation = () => useUpdateItemMutation("Page");
export const useCreatePageMutation = () => { export const useCreatePageMutation = () => useCreateItemMutation("Page");
const { courseName } = useCourseContext();
const queryClient = useQueryClient();
return useMutation({
mutationFn: async ({
page,
moduleName,
pageName,
}: {
page: LocalCoursePage;
moduleName: string;
pageName: string;
}) => {
queryClient.setQueryData(
localCourseKeys.itemOfType(courseName, moduleName, pageName, "Page"),
page
);
const url =
"/api/courses/" +
encodeURIComponent(courseName) +
"/modules/" +
encodeURIComponent(moduleName) +
"/pages/" +
encodeURIComponent(pageName);
await axiosClient.post(url, page);
},
onSuccess: (_, { moduleName, pageName }) => {
queryClient.invalidateQueries({
queryKey: localCourseKeys.itemOfType(
courseName,
moduleName,
pageName,
"Page"
),
});
queryClient.invalidateQueries({
queryKey: localCourseKeys.itemOfType(
courseName,
moduleName,
pageName,
"Page"
),
});
},
});
};
export const useDeletePageMutation = () => { export const useDeletePageMutation = () => {
const { courseName } = useCourseContext(); const { courseName } = useCourseContext();

View File

@@ -1,5 +1,4 @@
"use client"; "use client";
import { LocalQuiz } from "@/models/local/quiz/localQuiz";
import { import {
useMutation, useMutation,
useQueryClient, useQueryClient,
@@ -10,6 +9,7 @@ import { axiosClient } from "@/services/axiosUtils";
import { import {
getAllItemsQueryConfig, getAllItemsQueryConfig,
getItemQueryConfig, getItemQueryConfig,
useCreateItemMutation,
useItemQuery, useItemQuery,
useItemsQueries, useItemsQueries,
useUpdateItemMutation, useUpdateItemMutation,
@@ -38,51 +38,7 @@ export const useQuizzesQueries = (moduleName: string) =>
export const useUpdateQuizMutation = () => useUpdateItemMutation("Quiz") export const useUpdateQuizMutation = () => useUpdateItemMutation("Quiz")
export const useCreateQuizMutation = () => { export const useCreateQuizMutation = () => useCreateItemMutation("Quiz")
const { courseName } = useCourseContext();
const queryClient = useQueryClient();
return useMutation({
mutationFn: async ({
quiz,
moduleName,
quizName,
}: {
quiz: LocalQuiz;
moduleName: string;
quizName: string;
}) => {
queryClient.setQueryData(
localCourseKeys.itemOfType(courseName, moduleName, quizName, "Quiz"),
quiz
);
const url =
"/api/courses/" +
encodeURIComponent(courseName) +
"/modules/" +
encodeURIComponent(moduleName) +
"/quizzes/" +
encodeURIComponent(quizName);
await axiosClient.post(url, quiz);
},
onSuccess: async (_, { moduleName, quizName }) => {
await queryClient.invalidateQueries({
queryKey: localCourseKeys.allItemsOfType(
courseName,
moduleName,
"Quiz"
),
});
await queryClient.invalidateQueries({
queryKey: localCourseKeys.itemOfType(
courseName,
moduleName,
quizName,
"Quiz"
),
});
},
});
};
export const useDeleteQuizMutation = () => { export const useDeleteQuizMutation = () => {
const { courseName } = useCourseContext(); const { courseName } = useCourseContext();