mirror of
https://github.com/alexmickelson/canvasManagement.git
synced 2026-03-25 23:28:33 -06:00
more consolodation
This commit is contained in:
@@ -73,7 +73,7 @@ export default function NewItemForm({
|
||||
}
|
||||
if (type === "Assignment") {
|
||||
createAssignment.mutate({
|
||||
assignment: {
|
||||
item: {
|
||||
name,
|
||||
description: "",
|
||||
dueAt,
|
||||
@@ -85,11 +85,11 @@ export default function NewItemForm({
|
||||
rubric: [],
|
||||
},
|
||||
moduleName: moduleName,
|
||||
assignmentName: name,
|
||||
itemName: name,
|
||||
});
|
||||
} else if (type === "Quiz") {
|
||||
createQuiz.mutate({
|
||||
quiz: {
|
||||
item: {
|
||||
name,
|
||||
description: "",
|
||||
dueAt,
|
||||
@@ -100,17 +100,17 @@ export default function NewItemForm({
|
||||
questions: [],
|
||||
},
|
||||
moduleName: moduleName,
|
||||
quizName: name,
|
||||
itemName: name,
|
||||
});
|
||||
} else if (type === "Page") {
|
||||
createPage.mutate({
|
||||
page: {
|
||||
item: {
|
||||
name,
|
||||
text: "",
|
||||
dueAt,
|
||||
},
|
||||
moduleName: moduleName,
|
||||
pageName: name,
|
||||
itemName: name,
|
||||
});
|
||||
}
|
||||
onCreate();
|
||||
|
||||
@@ -12,6 +12,7 @@ import { axiosClient } from "@/services/axiosUtils";
|
||||
import {
|
||||
getAllItemsQueryConfig,
|
||||
getItemQueryConfig,
|
||||
useCreateItemMutation,
|
||||
useItemQuery,
|
||||
useItemsQueries,
|
||||
useUpdateItemMutation,
|
||||
@@ -39,56 +40,8 @@ export const useAssignmentsQueries = (moduleName: string) =>
|
||||
export const useUpdateAssignmentMutation = () =>
|
||||
useUpdateItemMutation("Assignment");
|
||||
|
||||
export const useCreateAssignmentMutation = () => {
|
||||
const { courseName } = useCourseContext();
|
||||
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 useCreateAssignmentMutation = () =>
|
||||
useCreateItemMutation("Assignment");
|
||||
|
||||
export const useDeleteAssignmentMutation = () => {
|
||||
const { courseName } = useCourseContext();
|
||||
|
||||
@@ -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
|
||||
),
|
||||
});
|
||||
},
|
||||
});
|
||||
};
|
||||
|
||||
@@ -7,6 +7,7 @@ import { axiosClient } from "@/services/axiosUtils";
|
||||
import {
|
||||
getAllItemsQueryConfig,
|
||||
getItemQueryConfig,
|
||||
useCreateItemMutation,
|
||||
useItemQuery,
|
||||
useItemsQueries,
|
||||
useUpdateItemMutation,
|
||||
@@ -32,52 +33,7 @@ export const usePagesQueries = (moduleName: string) =>
|
||||
|
||||
export const useUpdatePageMutation = () => useUpdateItemMutation("Page");
|
||||
|
||||
export const useCreatePageMutation = () => {
|
||||
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 useCreatePageMutation = () => useCreateItemMutation("Page");
|
||||
|
||||
export const useDeletePageMutation = () => {
|
||||
const { courseName } = useCourseContext();
|
||||
|
||||
@@ -1,5 +1,4 @@
|
||||
"use client";
|
||||
import { LocalQuiz } from "@/models/local/quiz/localQuiz";
|
||||
import {
|
||||
useMutation,
|
||||
useQueryClient,
|
||||
@@ -10,6 +9,7 @@ import { axiosClient } from "@/services/axiosUtils";
|
||||
import {
|
||||
getAllItemsQueryConfig,
|
||||
getItemQueryConfig,
|
||||
useCreateItemMutation,
|
||||
useItemQuery,
|
||||
useItemsQueries,
|
||||
useUpdateItemMutation,
|
||||
@@ -38,51 +38,7 @@ export const useQuizzesQueries = (moduleName: string) =>
|
||||
|
||||
export const useUpdateQuizMutation = () => useUpdateItemMutation("Quiz")
|
||||
|
||||
export const useCreateQuizMutation = () => {
|
||||
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 useCreateQuizMutation = () => useCreateItemMutation("Quiz")
|
||||
|
||||
export const useDeleteQuizMutation = () => {
|
||||
const { courseName } = useCourseContext();
|
||||
|
||||
Reference in New Issue
Block a user