mirror of
https://github.com/alexmickelson/canvasManagement.git
synced 2026-03-26 07:38:33 -06:00
more consolodation
This commit is contained in:
@@ -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();
|
||||||
|
|||||||
@@ -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();
|
||||||
|
|||||||
@@ -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 {
|
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();
|
||||||
|
|||||||
@@ -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();
|
||||||
|
|||||||
Reference in New Issue
Block a user