"use client"; import ButtonSelect from "@/components/ButtonSelect"; import { DayOfWeekInput } from "@/components/form/DayOfWeekInput"; import SelectInput from "@/components/form/SelectInput"; import { StoragePathSelector } from "@/components/form/StoragePathSelector"; import TextInput from "@/components/form/TextInput"; import { Spinner } from "@/components/Spinner"; import { SuspenseAndErrorHandling } from "@/components/SuspenseAndErrorHandling"; import { useCourseListInTermQuery } from "@/hooks/canvas/canvasCourseHooks"; import { useCanvasTermsQuery } from "@/hooks/canvas/canvasHooks"; import { useCreateLocalCourseMutation, useLocalCoursesSettingsQuery, } from "@/features/local/course/localCoursesHooks"; import { CanvasCourseModel } from "@/models/canvas/courses/canvasCourseModel"; import { CanvasEnrollmentTermModel } from "@/models/canvas/enrollmentTerms/canvasEnrollmentTermModel"; import { AssignmentSubmissionType } from "@/features/local/assignments/models/assignmentSubmissionType"; import { getCourseUrl } from "@/services/urlUtils"; import { useRouter } from "next/navigation"; import React, { Dispatch, SetStateAction, useMemo, useState } from "react"; import { DayOfWeek, LocalCourseSettings, } from "@/features/local/course/localCourseSettings"; const sampleCompose = `services: canvas_manager: image: alexmickelson/canvas_management:2 # pull this image regularly user: 1000:1000 # userid:groupid that matches file ownership on host system (probably leave like this) ports: - 8080:3000 # hostPort:containerPort - you can change the host port if you like env_file: - .env # needs to have your CANVAS_TOKEN set environment: - TZ=America/Denver # prevents timezone issues for due dates # - FILE_POLLING=true # increases cpu usage, uncomment if source volumes are on ntfs volumes: - ~/projects/faculty/1430/2024-fall-alex/modules:/app/storage/UX - ~/projects/faculty/4850_AdvancedFE/2024-fall-alex/modules:/app/storage/advanced_frontend `; export default function AddNewCourseToGlobalSettingsForm() { const router = useRouter(); const today = useMemo(() => new Date(), []); const { data: canvasTerms } = useCanvasTermsQuery(today); const [selectedTerm, setSelectedTerm] = useState< CanvasEnrollmentTermModel | undefined >(); const [selectedDaysOfWeek, setSelectedDaysOfWeek] = useState([]); const [selectedCanvasCourse, setSelectedCanvasCourse] = useState< CanvasCourseModel | undefined >(); const [selectedDirectory, setSelectedDirectory] = useState< string | undefined >(); const [courseToImport, setCourseToImport] = useState< LocalCourseSettings | undefined >(); const [name, setName] = useState(""); const createCourse = useCreateLocalCourseMutation(); const formIsComplete = selectedTerm && selectedCanvasCourse && selectedDirectory; return (
t?.name ?? ""} setValue={setSelectedTerm} value={selectedTerm} label={"Canvas Term"} center={true} /> {selectedTerm && ( )}
{createCourse.isPending && }
        
Example docker compose
{sampleCompose}
); } function OtherSettings({ selectedTerm, selectedCanvasCourse, setSelectedCanvasCourse, selectedDirectory: _, setSelectedDirectory, selectedDaysOfWeek, setSelectedDaysOfWeek, courseToImport, setCourseToImport, name, setName, }: { selectedTerm: CanvasEnrollmentTermModel; selectedCanvasCourse: CanvasCourseModel | undefined; setSelectedCanvasCourse: Dispatch< SetStateAction >; selectedDirectory: string | undefined; setSelectedDirectory: Dispatch>; selectedDaysOfWeek: DayOfWeek[]; setSelectedDaysOfWeek: Dispatch>; courseToImport: LocalCourseSettings | undefined; setCourseToImport: Dispatch>; name: string; setName: Dispatch>; }) { const { data: canvasCourses } = useCourseListInTermQuery(selectedTerm.id); const { data: allSettings } = useLocalCoursesSettingsQuery(); const [directory, setDirectory] = useState("./"); // const directoryIsCourseQuery = useDirectoryIsCourseQuery( // selectedDirectory ?? "./" // ); const populatedCanvasCourseIds = allSettings?.map((s) => s.canvasId) ?? []; const availableCourses = canvasCourses?.filter( (canvas: CanvasCourseModel) => !populatedCanvasCourseIds.includes(canvas.id) ) ?? []; return ( <> c?.name ?? ""} center={true} />
{ setSelectedDaysOfWeek((oldDays) => { const hasDay = oldDays.includes(day); return hasDay ? oldDays.filter((d) => d !== day) : [day, ...oldDays]; }); }} />
c.name} />
Assignments, Quizzes, Pages, and Lectures will have their due dates moved based on how far they are from the start of the semester.
You will still need to go through and re-order the course content, but things will be within a few days of where they should be.
); }