Corrected list-task relationship

This commit is contained in:
2024-11-23 09:29:43 -06:00
parent 66662220e7
commit 30f44c75b5
2 changed files with 30 additions and 10 deletions

View File

@@ -8,6 +8,11 @@ import {
import { createTRPCRouter, protectedProcedure } from "~/server/api/trpc";
import { lists } from "~/server/db/schema";
const formatList = (list: typeof lists.$inferInsert) => ({
...list,
labels: list.labels?.split(",") ?? [],
});
export const listRouter = createTRPCRouter({
create: protectedProcedure
.input(listCreationFormSchema)
@@ -23,24 +28,38 @@ export const listRouter = createTRPCRouter({
),
getAll: protectedProcedure.query(async ({ ctx }) => {
const allLists = await ctx.db.query.lists.findMany({
where: and(eq(lists.userId, ctx.session.user.id)),
where: eq(lists.userId, ctx.session.user.id),
});
const formattedLists = allLists.map((list) => ({
...list,
labels: list.labels?.split(",") ?? [],
}));
const formattedLists = allLists.map(formatList);
return formattedLists;
}),
get: protectedProcedure
.input(z.object({ listId: z.coerce.number() }))
.query(async ({ ctx, input }) => {
return { name: "Groceries", tasks: [] };
const list = await ctx.db.query.lists.findFirst({
where: and(
eq(lists.userId, ctx.session.user.id),
eq(lists.id, input.listId),
),
with: { tasks: true },
});
// TODO: Error - no list found
if (!list) {
return;
}
const formattedList = { ...formatList(list), tasks: list.tasks };
return formattedList;
}),
update: protectedProcedure
.input(z.object({ listId: z.number(), title: listTitleSchema }))
.mutation(async ({ ctx, input }) => {
return [];
}),
.mutation(({ ctx, input }) =>
ctx.db
.update(lists)
.set({ title: input.title })
.where(eq(lists.id, input.listId)),
),
delete: protectedProcedure
.input(z.object({ listId: z.number() }))
.mutation(async ({ ctx, input }) => {