mirror of
https://github.com/alexmickelson/canvasManagement.git
synced 2026-03-25 23:28:33 -06:00
refactoring files to be located by feature
This commit is contained in:
98
src/features/local/pages/pageHooks.ts
Normal file
98
src/features/local/pages/pageHooks.ts
Normal file
@@ -0,0 +1,98 @@
|
||||
"use client";
|
||||
import { useCourseContext } from "@/app/course/[courseName]/context/courseContext";
|
||||
import { useTRPC } from "@/services/serverFunctions/trpcClient";
|
||||
import {
|
||||
useSuspenseQuery,
|
||||
useMutation,
|
||||
useQueryClient,
|
||||
} from "@tanstack/react-query";
|
||||
|
||||
export const usePageQuery = (moduleName: string, pageName: string) => {
|
||||
const { courseName } = useCourseContext();
|
||||
const trpc = useTRPC();
|
||||
return useSuspenseQuery(
|
||||
trpc.page.getPage.queryOptions({
|
||||
courseName,
|
||||
moduleName,
|
||||
pageName,
|
||||
})
|
||||
);
|
||||
};
|
||||
|
||||
export const usePagesQueries = (moduleName: string) => {
|
||||
const { courseName } = useCourseContext();
|
||||
const trpc = useTRPC();
|
||||
return useSuspenseQuery(
|
||||
trpc.page.getAllPages.queryOptions({
|
||||
courseName,
|
||||
moduleName,
|
||||
})
|
||||
);
|
||||
};
|
||||
|
||||
export const useUpdatePageMutation = () => {
|
||||
const trpc = useTRPC();
|
||||
const queryClient = useQueryClient();
|
||||
return useMutation(
|
||||
trpc.page.updatePage.mutationOptions({
|
||||
onSuccess: (
|
||||
_,
|
||||
{ courseName, moduleName, pageName, previousModuleName }
|
||||
) => {
|
||||
queryClient.invalidateQueries({
|
||||
queryKey: trpc.page.getAllPages.queryKey({ courseName, moduleName }),
|
||||
});
|
||||
queryClient.invalidateQueries({
|
||||
queryKey: trpc.page.getPage.queryKey({
|
||||
courseName,
|
||||
moduleName,
|
||||
pageName,
|
||||
}),
|
||||
});
|
||||
if (moduleName !== previousModuleName) {
|
||||
queryClient.invalidateQueries({
|
||||
queryKey: trpc.page.getAllPages.queryKey({
|
||||
courseName,
|
||||
moduleName: previousModuleName,
|
||||
}),
|
||||
});
|
||||
}
|
||||
},
|
||||
})
|
||||
);
|
||||
};
|
||||
|
||||
export const useCreatePageMutation = () => {
|
||||
const trpc = useTRPC();
|
||||
const queryClient = useQueryClient();
|
||||
return useMutation(
|
||||
trpc.page.createPage.mutationOptions({
|
||||
onSuccess: (_, { courseName, moduleName }) => {
|
||||
queryClient.invalidateQueries({
|
||||
queryKey: trpc.page.getAllPages.queryKey({ courseName, moduleName }),
|
||||
});
|
||||
},
|
||||
})
|
||||
);
|
||||
};
|
||||
|
||||
export const useDeletePageMutation = () => {
|
||||
const trpc = useTRPC();
|
||||
const queryClient = useQueryClient();
|
||||
return useMutation(
|
||||
trpc.page.deletePage.mutationOptions({
|
||||
onSuccess: (_, { courseName, moduleName, pageName }) => {
|
||||
queryClient.invalidateQueries({
|
||||
queryKey: trpc.page.getAllPages.queryKey({ courseName, moduleName }),
|
||||
});
|
||||
queryClient.invalidateQueries({
|
||||
queryKey: trpc.page.getPage.queryKey({
|
||||
courseName,
|
||||
moduleName,
|
||||
pageName,
|
||||
}),
|
||||
});
|
||||
},
|
||||
})
|
||||
);
|
||||
};
|
||||
Reference in New Issue
Block a user