mirror of
https://github.com/alexmickelson/canvasManagement.git
synced 2026-03-25 23:28:33 -06:00
optimistic updates
This commit is contained in:
@@ -3,6 +3,8 @@ import { ReactNode, useCallback, DragEvent } from "react";
|
||||
import { DraggingContext } from "./draggingContext";
|
||||
import { useUpdateQuizMutation } from "@/hooks/localCourse/quizHooks";
|
||||
import { useLocalCourseSettingsQuery } from "@/hooks/localCourse/localCoursesHooks";
|
||||
import { LocalQuiz } from "@/models/local/quiz/localQuiz";
|
||||
import { getDateFromStringOrThrow, dateToMarkdownString } from "@/models/local/timeUtils";
|
||||
|
||||
export default function DraggingContextProvider({
|
||||
children,
|
||||
@@ -15,47 +17,47 @@ export default function DraggingContextProvider({
|
||||
|
||||
const itemDrop = useCallback(
|
||||
(e: DragEvent<HTMLDivElement>, day: string | undefined) => {
|
||||
// const itemBeingDragged = JSON.parse(
|
||||
// e.dataTransfer.getData("draggableItem")
|
||||
// );
|
||||
const itemBeingDragged = JSON.parse(
|
||||
e.dataTransfer.getData("draggableItem")
|
||||
);
|
||||
|
||||
// if (itemBeingDragged && day) {
|
||||
// const dayAsDate = getDateFromStringOrThrow(day, "in drop callback");
|
||||
// dayAsDate.setHours(settings.defaultDueTime.hour);
|
||||
// dayAsDate.setMinutes(settings.defaultDueTime.minute);
|
||||
// dayAsDate.setSeconds(0);
|
||||
if (itemBeingDragged && day) {
|
||||
const dayAsDate = getDateFromStringOrThrow(day, "in drop callback");
|
||||
dayAsDate.setHours(settings.defaultDueTime.hour);
|
||||
dayAsDate.setMinutes(settings.defaultDueTime.minute);
|
||||
dayAsDate.setSeconds(0);
|
||||
|
||||
// console.log("dropped on day", dayAsDate, day);
|
||||
// if (itemBeingDragged.type === "quiz") {
|
||||
// console.log("dropping quiz");
|
||||
// const previousQuiz = itemBeingDragged.item as LocalQuiz;
|
||||
console.log("dropped on day", dayAsDate, day);
|
||||
if (itemBeingDragged.type === "quiz") {
|
||||
console.log("dropping quiz");
|
||||
const previousQuiz = itemBeingDragged.item as LocalQuiz;
|
||||
|
||||
// const quiz: LocalQuiz = {
|
||||
// ...previousQuiz,
|
||||
// dueAt: dateToMarkdownString(dayAsDate),
|
||||
// lockAt:
|
||||
// previousQuiz.lockAt &&
|
||||
// (getDateFromStringOrThrow(previousQuiz.lockAt, "lockAt date") >
|
||||
// dayAsDate
|
||||
// ? previousQuiz.lockAt
|
||||
// : dateToMarkdownString(dayAsDate)),
|
||||
// };
|
||||
// updateQuizMutation.mutate({
|
||||
// quiz: quiz,
|
||||
// quizName: quiz.name,
|
||||
// moduleName: itemBeingDragged.sourceModuleName,
|
||||
// });
|
||||
// } else if (itemBeingDragged.type === "assignment") {
|
||||
// console.log("dropped assignment");
|
||||
// } else if (itemBeingDragged.type === "page") {
|
||||
// console.log("dropped page");
|
||||
// }
|
||||
// }
|
||||
const quiz: LocalQuiz = {
|
||||
...previousQuiz,
|
||||
dueAt: dateToMarkdownString(dayAsDate),
|
||||
lockAt:
|
||||
previousQuiz.lockAt &&
|
||||
(getDateFromStringOrThrow(previousQuiz.lockAt, "lockAt date") >
|
||||
dayAsDate
|
||||
? previousQuiz.lockAt
|
||||
: dateToMarkdownString(dayAsDate)),
|
||||
};
|
||||
updateQuizMutation.mutate({
|
||||
quiz: quiz,
|
||||
quizName: quiz.name,
|
||||
moduleName: itemBeingDragged.sourceModuleName,
|
||||
});
|
||||
} else if (itemBeingDragged.type === "assignment") {
|
||||
console.log("dropped assignment");
|
||||
} else if (itemBeingDragged.type === "page") {
|
||||
console.log("dropped page");
|
||||
}
|
||||
}
|
||||
},
|
||||
[
|
||||
// settings.defaultDueTime.hour,
|
||||
// settings.defaultDueTime.minute,
|
||||
// updateQuizMutation,
|
||||
settings.defaultDueTime.hour,
|
||||
settings.defaultDueTime.minute,
|
||||
updateQuizMutation,
|
||||
]
|
||||
);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user