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