handling module items

This commit is contained in:
2024-09-23 16:12:55 -06:00
parent dcc2ca9099
commit 06073cbd1b
10 changed files with 123 additions and 21 deletions

View File

@@ -8,6 +8,11 @@ import {
} from "@tanstack/react-query";
import { useLocalCourseSettingsQuery } from "../localCourse/localCoursesHooks";
import { LocalAssignment } from "@/models/local/assignment/localAssignment";
import { canvasModuleService } from "@/services/canvas/canvasModuleService";
import {
useAddCanvasModuleMutation,
useCanvasModulesQuery,
} from "./canvasModuleHooks";
export const canvasAssignmentKeys = {
assignments: (canvasCourseId: number) =>
@@ -43,18 +48,38 @@ export const useCanvasAssignmentsQuery = () => {
export const useAddAssignmentToCanvasMutation = () => {
const { data: settings } = useLocalCourseSettingsQuery();
const { data: canvasModules } = useCanvasModulesQuery();
const addModule = useAddCanvasModuleMutation();
const queryClient = useQueryClient();
return useMutation({
mutationFn: async (assignment: LocalAssignment) => {
mutationFn: async ({
assignment,
moduleName,
}: {
assignment: LocalAssignment;
moduleName: string;
}) => {
const assignmentGroup = settings.assignmentGroups.find(
(g) => g.name === assignment.localAssignmentGroupName
);
await canvasAssignmentService.create(
const canvasAssignmentId = await canvasAssignmentService.create(
settings.canvasId,
assignment,
assignmentGroup?.canvasId
);
const canvasModule = canvasModules.find((c) => c.name === moduleName);
const moduleId = canvasModule
? canvasModule.id
: await addModule.mutateAsync(moduleName);
await canvasModuleService.createModuleItem(
settings.canvasId,
moduleId,
assignment.name,
"Assignment",
canvasAssignmentId
);
},
onSuccess: () => {
queryClient.invalidateQueries({

View File

@@ -1,7 +1,16 @@
import { LocalCoursePage } from "@/models/local/page/localCoursePage";
import { canvasPageService } from "@/services/canvas/canvasPageService";
import { useMutation, useQuery, useQueryClient, useSuspenseQuery } from "@tanstack/react-query";
import {
useMutation,
useQueryClient,
useSuspenseQuery,
} from "@tanstack/react-query";
import { useLocalCourseSettingsQuery } from "../localCourse/localCoursesHooks";
import { canvasModuleService } from "@/services/canvas/canvasModuleService";
import {
useCanvasModulesQuery,
useAddCanvasModuleMutation,
} from "./canvasModuleHooks";
export const canvasPageKeys = {
pagesInCourse: (courseCanvasId: number) => [
@@ -22,9 +31,35 @@ export const useCanvasPagesQuery = () => {
export const useCreateCanvasPageMutation = () => {
const { data: settings } = useLocalCourseSettingsQuery();
const queryClient = useQueryClient();
const { data: canvasModules } = useCanvasModulesQuery();
const addModule = useAddCanvasModuleMutation();
return useMutation({
mutationFn: async (page: LocalCoursePage) =>
canvasPageService.create(settings.canvasId, page),
mutationFn: async ({
page,
moduleName,
}: {
page: LocalCoursePage;
moduleName: string;
}) => {
const canvasPage = await canvasPageService.create(
settings.canvasId,
page
);
const canvasModule = canvasModules.find((c) => c.name === moduleName);
const moduleId = canvasModule
? canvasModule.id
: await addModule.mutateAsync(moduleName);
await canvasModuleService.createPageModuleItem(
settings.canvasId,
moduleId,
page.name,
canvasPage
);
return canvasPage;
},
onSuccess: () => {
queryClient.invalidateQueries({
queryKey: canvasPageKeys.pagesInCourse(settings.canvasId),

View File

@@ -6,6 +6,8 @@ import {
import { useLocalCourseSettingsQuery } from "../localCourse/localCoursesHooks";
import { canvasQuizService } from "@/services/canvas/canvasQuizService";
import { LocalQuiz } from "@/models/local/quiz/localQuiz";
import { useAddCanvasModuleMutation, useCanvasModulesQuery } from "./canvasModuleHooks";
import { canvasModuleService } from "@/services/canvas/canvasModuleService";
export const canvasQuizKeys = {
quizzes: (canvasCourseId: number) =>
@@ -24,17 +26,38 @@ export const useCanvasQuizzesQuery = () => {
export const useAddQuizToCanvasMutation = () => {
const { data: settings } = useLocalCourseSettingsQuery();
const queryClient = useQueryClient();
const { data: canvasModules } = useCanvasModulesQuery();
const addModule = useAddCanvasModuleMutation();
return useMutation({
mutationFn: async (quiz: LocalQuiz) => {
mutationFn: async ({
quiz,
moduleName,
}: {
quiz: LocalQuiz;
moduleName: string;
}) => {
const assignmentGroup = settings.assignmentGroups.find(
(g) => g.name === quiz.localAssignmentGroupName
);
await canvasQuizService.create(
const canvasQuizId = await canvasQuizService.create(
settings.canvasId,
quiz,
assignmentGroup?.canvasId
);
const canvasModule = canvasModules.find((c) => c.name === moduleName);
const moduleId = canvasModule
? canvasModule.id
: await addModule.mutateAsync(moduleName);
await canvasModuleService.createModuleItem(
settings.canvasId,
moduleId,
quiz.name,
"Quiz",
canvasQuizId
);
},
onSuccess: () => {
queryClient.invalidateQueries({