mirror of
https://github.com/alexmickelson/canvasManagement.git
synced 2026-03-26 23:58:31 -06:00
moving v2 to top level
This commit is contained in:
102
src/hooks/canvas/canvasPageHooks.ts
Normal file
102
src/hooks/canvas/canvasPageHooks.ts
Normal file
@@ -0,0 +1,102 @@
|
||||
import { LocalCoursePage } from "@/models/local/page/localCoursePage";
|
||||
import { canvasPageService } from "@/services/canvas/canvasPageService";
|
||||
import { useMutation, useQuery, useQueryClient } 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) => [
|
||||
"canvas",
|
||||
courseCanvasId,
|
||||
"pages",
|
||||
],
|
||||
};
|
||||
|
||||
export const useCanvasPagesQuery = () => {
|
||||
const [settings] = useLocalCourseSettingsQuery();
|
||||
return useQuery({
|
||||
queryKey: canvasPageKeys.pagesInCourse(settings.canvasId),
|
||||
queryFn: async () => await canvasPageService.getAll(settings.canvasId),
|
||||
});
|
||||
};
|
||||
|
||||
export const useCreateCanvasPageMutation = () => {
|
||||
const [settings] = useLocalCourseSettingsQuery();
|
||||
const queryClient = useQueryClient();
|
||||
const { data: canvasModules } = useCanvasModulesQuery();
|
||||
const addModule = useAddCanvasModuleMutation();
|
||||
|
||||
return useMutation({
|
||||
mutationFn: async ({
|
||||
page,
|
||||
moduleName,
|
||||
}: {
|
||||
page: LocalCoursePage;
|
||||
moduleName: string;
|
||||
}) => {
|
||||
if (!canvasModules) {
|
||||
console.log("cannot add page until modules loaded");
|
||||
return;
|
||||
}
|
||||
const canvasPage = await canvasPageService.create(
|
||||
settings.canvasId,
|
||||
page,settings
|
||||
);
|
||||
|
||||
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),
|
||||
});
|
||||
},
|
||||
});
|
||||
};
|
||||
|
||||
export const useUpdateCanvasPageMutation = () => {
|
||||
const [settings] = useLocalCourseSettingsQuery();
|
||||
const queryClient = useQueryClient();
|
||||
return useMutation({
|
||||
mutationFn: async ({
|
||||
page,
|
||||
canvasPageId,
|
||||
}: {
|
||||
page: LocalCoursePage;
|
||||
canvasPageId: number;
|
||||
}) => canvasPageService.update(settings.canvasId, canvasPageId, page, settings),
|
||||
onSuccess: () => {
|
||||
queryClient.invalidateQueries({
|
||||
queryKey: canvasPageKeys.pagesInCourse(settings.canvasId),
|
||||
});
|
||||
},
|
||||
});
|
||||
};
|
||||
|
||||
export const useDeleteCanvasPageMutation = () => {
|
||||
const [settings] = useLocalCourseSettingsQuery();
|
||||
const queryClient = useQueryClient();
|
||||
return useMutation({
|
||||
mutationFn: async (canvasPageId: number) =>
|
||||
canvasPageService.delete(settings.canvasId, canvasPageId),
|
||||
onSuccess: () => {
|
||||
queryClient.invalidateQueries({
|
||||
queryKey: canvasPageKeys.pagesInCourse(settings.canvasId),
|
||||
});
|
||||
},
|
||||
});
|
||||
};
|
||||
Reference in New Issue
Block a user