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

@@ -193,7 +193,7 @@ function AssignmentButtons({
{!assignmentInCanvas && ( {!assignmentInCanvas && (
<button <button
disabled={addToCanvas.isPending} disabled={addToCanvas.isPending}
onClick={() => addToCanvas.mutate(assignment)} onClick={() => addToCanvas.mutate({ assignment, moduleName })}
> >
Add to canvas Add to canvas
</button> </button>

View File

@@ -40,7 +40,7 @@ export default function EditPageButtons({
{requestIsPending && <Spinner />} {requestIsPending && <Spinner />}
{!pageInCanvas && ( {!pageInCanvas && (
<button <button
onClick={() => createPageInCanvas.mutate(page)} onClick={() => createPageInCanvas.mutate({ page, moduleName })}
disabled={requestIsPending} disabled={requestIsPending}
> >
Add to Canvas Add to Canvas

View File

@@ -1,6 +1,10 @@
import { useCourseContext } from "@/app/course/[courseName]/context/courseContext"; import { useCourseContext } from "@/app/course/[courseName]/context/courseContext";
import { Spinner } from "@/components/Spinner"; import { Spinner } from "@/components/Spinner";
import { useCanvasQuizzesQuery, useAddQuizToCanvasMutation, useDeleteQuizFromCanvasMutation } from "@/hooks/canvas/canvasQuizHooks"; import {
useCanvasQuizzesQuery,
useAddQuizToCanvasMutation,
useDeleteQuizFromCanvasMutation,
} from "@/hooks/canvas/canvasQuizHooks";
import { useLocalCourseSettingsQuery } from "@/hooks/localCourse/localCoursesHooks"; import { useLocalCourseSettingsQuery } from "@/hooks/localCourse/localCoursesHooks";
import { useQuizQuery } from "@/hooks/localCourse/quizHooks"; import { useQuizQuery } from "@/hooks/localCourse/quizHooks";
import { baseCanvasUrl } from "@/services/canvas/canvasServiceUtils"; import { baseCanvasUrl } from "@/services/canvas/canvasServiceUtils";
@@ -38,9 +42,9 @@ export function QuizButtons({
{!quizInCanvas && ( {!quizInCanvas && (
<button <button
disabled={addToCanvas.isPending} disabled={addToCanvas.isPending}
onClick={() => addToCanvas.mutate(quiz)} onClick={() => addToCanvas.mutate({ quiz, moduleName })}
> >
Add to canvas.... Add to canvas
</button> </button>
)} )}
{quizInCanvas && ( {quizInCanvas && (

View File

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

View File

@@ -1,7 +1,16 @@
import { LocalCoursePage } from "@/models/local/page/localCoursePage"; import { LocalCoursePage } from "@/models/local/page/localCoursePage";
import { canvasPageService } from "@/services/canvas/canvasPageService"; 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 { useLocalCourseSettingsQuery } from "../localCourse/localCoursesHooks";
import { canvasModuleService } from "@/services/canvas/canvasModuleService";
import {
useCanvasModulesQuery,
useAddCanvasModuleMutation,
} from "./canvasModuleHooks";
export const canvasPageKeys = { export const canvasPageKeys = {
pagesInCourse: (courseCanvasId: number) => [ pagesInCourse: (courseCanvasId: number) => [
@@ -22,9 +31,35 @@ export const useCanvasPagesQuery = () => {
export const useCreateCanvasPageMutation = () => { export const useCreateCanvasPageMutation = () => {
const { data: settings } = useLocalCourseSettingsQuery(); const { data: settings } = useLocalCourseSettingsQuery();
const queryClient = useQueryClient(); const queryClient = useQueryClient();
const { data: canvasModules } = useCanvasModulesQuery();
const addModule = useAddCanvasModuleMutation();
return useMutation({ return useMutation({
mutationFn: async (page: LocalCoursePage) => mutationFn: async ({
canvasPageService.create(settings.canvasId, page), 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: () => { onSuccess: () => {
queryClient.invalidateQueries({ queryClient.invalidateQueries({
queryKey: canvasPageKeys.pagesInCourse(settings.canvasId), queryKey: canvasPageKeys.pagesInCourse(settings.canvasId),

View File

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

View File

@@ -6,6 +6,8 @@ import { markdownToHTMLSafe } from "../htmlMarkdownUtils";
import { CanvasRubricCreationResponse } from "@/models/canvas/assignments/canvasRubricCreationResponse"; import { CanvasRubricCreationResponse } from "@/models/canvas/assignments/canvasRubricCreationResponse";
import { assignmentPoints } from "@/models/local/assignment/utils/assignmentPointsUtils"; import { assignmentPoints } from "@/models/local/assignment/utils/assignmentPointsUtils";
import { getDateFromString } from "@/models/local/timeUtils"; import { getDateFromString } from "@/models/local/timeUtils";
import { canvasModuleService } from "./canvasModuleService";
import { CanvasModule } from "@/models/canvas/modules/canvasModule";
export const canvasAssignmentService = { export const canvasAssignmentService = {
@@ -23,7 +25,7 @@ export const canvasAssignmentService = {
async create( async create(
canvasCourseId: number, canvasCourseId: number,
localAssignment: LocalAssignment, localAssignment: LocalAssignment,
canvasAssignmentGroupId?: number canvasAssignmentGroupId?: number,
) { ) {
console.log(`Creating assignment: ${localAssignment.name}`); console.log(`Creating assignment: ${localAssignment.name}`);
const url = `${canvasApi}/courses/${canvasCourseId}/assignments`; const url = `${canvasApi}/courses/${canvasCourseId}/assignments`;

View File

@@ -24,9 +24,9 @@ export const canvasModuleService = {
canvasCourseId: number, canvasCourseId: number,
canvasModuleId: number, canvasModuleId: number,
title: string, title: string,
type: string, type: "Assignment" | "Quiz",
contentId: number | string contentId: number | string
): Promise<void> { ) {
console.log(`Creating new module item ${title}`); console.log(`Creating new module item ${title}`);
const url = `${canvasApi}/courses/${canvasCourseId}/modules/${canvasModuleId}/items`; const url = `${canvasApi}/courses/${canvasCourseId}/modules/${canvasModuleId}/items`;
const body = { module_item: { title, type, content_id: contentId } }; const body = { module_item: { title, type, content_id: contentId } };
@@ -38,7 +38,7 @@ export const canvasModuleService = {
canvasModuleId: number, canvasModuleId: number,
title: string, title: string,
canvasPage: CanvasPage canvasPage: CanvasPage
): Promise<void> { ) {
console.log(`Creating new module item ${title}`); console.log(`Creating new module item ${title}`);
const url = `${canvasApi}/courses/${canvasCourseId}/modules/${canvasModuleId}/items`; const url = `${canvasApi}/courses/${canvasCourseId}/modules/${canvasModuleId}/items`;
const body = { const body = {
@@ -60,6 +60,7 @@ export const canvasModuleService = {
name: moduleName, name: moduleName,
}, },
}; };
await axiosClient.post(url, body); const response = await axiosClient.post<CanvasModule>(url, body);
return response.data.id;
}, },
}; };

View File

@@ -127,7 +127,7 @@ export const canvasQuizService = {
canvasCourseId: number, canvasCourseId: number,
localQuiz: LocalQuiz, localQuiz: LocalQuiz,
canvasAssignmentGroupId?: number canvasAssignmentGroupId?: number
): Promise<number> { ) {
console.log("Creating quiz", localQuiz); console.log("Creating quiz", localQuiz);
const url = `${canvasApi}/courses/${canvasCourseId}/quizzes`; const url = `${canvasApi}/courses/${canvasCourseId}/quizzes`;
@@ -158,8 +158,6 @@ export const canvasQuizService = {
}; };
const { data: canvasQuiz } = await axiosClient.post<CanvasQuiz>(url, body); const { data: canvasQuiz } = await axiosClient.post<CanvasQuiz>(url, body);
if (!canvasQuiz) throw new Error("Created quiz is null");
await createQuizQuestions(canvasCourseId, canvasQuiz.id, localQuiz); await createQuizQuestions(canvasCourseId, canvasQuiz.id, localQuiz);
return canvasQuiz.id; return canvasQuiz.id;
}, },

View File

@@ -140,3 +140,17 @@ Authorization: Bearer {{$dotenv CANVAS_TOKEN}}
### ###
GET https://snow.instructure.com/api/v1/courses/871954 GET https://snow.instructure.com/api/v1/courses/871954
Authorization: Bearer {{$dotenv CANVAS_TOKEN}} Authorization: Bearer {{$dotenv CANVAS_TOKEN}}
###
POST https://snow.instructure.com/api/v1/courses/960410/modules
Authorization: Bearer {{$dotenv CANVAS_TOKEN}}
Content-Type: application/json
{
"module": {
"name": "test module"
}
}