feat: submission query POST en DELETE
This commit is contained in:
parent
2cda69ef5e
commit
0784db3680
2 changed files with 40 additions and 5 deletions
|
@ -66,7 +66,7 @@ export function useGroupQuery(
|
||||||
|
|
||||||
// TODO: find way to check if cid and an are not undefined.
|
// TODO: find way to check if cid and an are not undefined.
|
||||||
// depends on how this function is used.
|
// depends on how this function is used.
|
||||||
export function useCreateClassMutation(
|
export function useCreateGroupMutation(
|
||||||
classid: MaybeRefOrGetter<string | undefined>,
|
classid: MaybeRefOrGetter<string | undefined>,
|
||||||
assignmentNumber: MaybeRefOrGetter<number | undefined>,
|
assignmentNumber: MaybeRefOrGetter<number | undefined>,
|
||||||
): UseMutationReturnType<GroupResponse, Error, GroupDTO, unknown> {
|
): UseMutationReturnType<GroupResponse, Error, GroupDTO, unknown> {
|
||||||
|
@ -82,7 +82,7 @@ export function useCreateClassMutation(
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
export function useDeleteClassMutation(
|
export function useDeleteGroupMutation(
|
||||||
classid: MaybeRefOrGetter<string | undefined>,
|
classid: MaybeRefOrGetter<string | undefined>,
|
||||||
assignmentNumber: MaybeRefOrGetter<number | undefined>,
|
assignmentNumber: MaybeRefOrGetter<number | undefined>,
|
||||||
): UseMutationReturnType<GroupResponse, Error, number, unknown> {
|
): UseMutationReturnType<GroupResponse, Error, number, unknown> {
|
||||||
|
@ -91,7 +91,7 @@ export function useDeleteClassMutation(
|
||||||
|
|
||||||
return useMutation({
|
return useMutation({
|
||||||
mutationFn: async (id) => groupController.deleteGroup(cid!, an!, id),
|
mutationFn: async (id) => groupController.deleteGroup(cid!, an!, id),
|
||||||
onSuccess: async (_) => {
|
onSuccess: async () => {
|
||||||
await queryClient.invalidateQueries({ queryKey: groupQueryKey(cid!, an!, gn!) });
|
await queryClient.invalidateQueries({ queryKey: groupQueryKey(cid!, an!, gn!) });
|
||||||
|
|
||||||
await queryClient.invalidateQueries({ queryKey: groupsQueryKey(cid!, an!, true) });
|
await queryClient.invalidateQueries({ queryKey: groupsQueryKey(cid!, an!, true) });
|
||||||
|
@ -106,7 +106,7 @@ export function useDeleteClassMutation(
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
export function useUpdateClassMutation(
|
export function useUpdateGroupMutation(
|
||||||
classid: MaybeRefOrGetter<string | undefined>,
|
classid: MaybeRefOrGetter<string | undefined>,
|
||||||
assignmentNumber: MaybeRefOrGetter<number | undefined>,
|
assignmentNumber: MaybeRefOrGetter<number | undefined>,
|
||||||
): UseMutationReturnType<GroupResponse, Error, GroupDTO, unknown> {
|
): UseMutationReturnType<GroupResponse, Error, GroupDTO, unknown> {
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
import { SubmissionController, type SubmissionResponse, type SubmissionsResponse } from "@/controllers/submissions";
|
import { SubmissionController, type SubmissionResponse, type SubmissionsResponse } from "@/controllers/submissions";
|
||||||
import { useQuery, type UseQueryReturnType } from "@tanstack/vue-query";
|
import type { SubmissionDTO } from "@dwengo-1/common/interfaces/submission";
|
||||||
|
import { useMutation, useQuery, useQueryClient, type UseMutationReturnType, type UseQueryReturnType } from "@tanstack/vue-query";
|
||||||
import { computed, toValue, type MaybeRefOrGetter } from "vue";
|
import { computed, toValue, type MaybeRefOrGetter } from "vue";
|
||||||
|
|
||||||
function submissionsQueryKey(classid: string, assignmentNumber: number, full: boolean) {
|
function submissionsQueryKey(classid: string, assignmentNumber: number, full: boolean) {
|
||||||
|
@ -64,3 +65,37 @@ export function useSubmissionQuery(
|
||||||
enabled: () => checkEnabled(cid, an, gn, sn),
|
enabled: () => checkEnabled(cid, an, gn, sn),
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export function useCreateSubmissionMutation(
|
||||||
|
classid: MaybeRefOrGetter<string | undefined>,
|
||||||
|
assignmentNumber: MaybeRefOrGetter<number | undefined>,
|
||||||
|
groupNumber: MaybeRefOrGetter<number | undefined>,
|
||||||
|
): UseMutationReturnType<SubmissionResponse, Error, SubmissionDTO, unknown> {
|
||||||
|
const queryClient = useQueryClient();
|
||||||
|
const { cid, an, gn } = toValues(classid, assignmentNumber, groupNumber, 1, true);
|
||||||
|
|
||||||
|
return useMutation({
|
||||||
|
mutationFn: async (data) => new SubmissionController(cid!, an!, gn!).createSubmission(data),
|
||||||
|
onSuccess: async () => {
|
||||||
|
await queryClient.invalidateQueries({ queryKey: submissionsQueryKey(cid!, an!, true) });
|
||||||
|
await queryClient.invalidateQueries({ queryKey: submissionsQueryKey(cid!, an!, false) });
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
export function useDeleteGroupMutation(
|
||||||
|
classid: MaybeRefOrGetter<string | undefined>,
|
||||||
|
assignmentNumber: MaybeRefOrGetter<number | undefined>,
|
||||||
|
groupNumber: MaybeRefOrGetter<number | undefined>,
|
||||||
|
): UseMutationReturnType<SubmissionResponse, Error, number, unknown> {
|
||||||
|
const queryClient = useQueryClient();
|
||||||
|
const { cid, an, gn } = toValues(classid, assignmentNumber, groupNumber, 1, true);
|
||||||
|
|
||||||
|
return useMutation({
|
||||||
|
mutationFn: async (id) => new SubmissionController(cid!, an!, gn!).deleteSubmission(id),
|
||||||
|
onSuccess: async () => {
|
||||||
|
await queryClient.invalidateQueries({ queryKey: submissionsQueryKey(cid!, an!, true) });
|
||||||
|
await queryClient.invalidateQueries({ queryKey: submissionsQueryKey(cid!, an!, false) });
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue