From 7956e9fa6772ab57a0794fb7cba7e9d9c0bd7878 Mon Sep 17 00:00:00 2001 From: Mohamed Bassem Date: Sat, 28 Dec 2024 12:30:24 +0000 Subject: feat: Implement the all highlights page. Fixes #620 --- packages/trpc/routers/highlights.ts | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) (limited to 'packages/trpc') diff --git a/packages/trpc/routers/highlights.ts b/packages/trpc/routers/highlights.ts index e4446679..86da560b 100644 --- a/packages/trpc/routers/highlights.ts +++ b/packages/trpc/routers/highlights.ts @@ -1,10 +1,11 @@ import { experimental_trpcMiddleware, TRPCError } from "@trpc/server"; -import { and, eq, lt, lte, or } from "drizzle-orm"; +import { and, desc, eq, lt, lte, or } from "drizzle-orm"; import { z } from "zod"; import { highlights } from "@hoarder/db/schema"; import { DEFAULT_NUM_HIGHLIGHTS_PER_PAGE, + zGetAllHighlightsResponseSchema, zHighlightSchema, zNewHighlightSchema, zUpdateHighlightSchema, @@ -76,6 +77,7 @@ export const highlightsAppRouter = router({ eq(highlights.bookmarkId, input.bookmarkId), eq(highlights.userId, ctx.user.id), ), + orderBy: [desc(highlights.createdAt), desc(highlights.id)], }); return { highlights: results }; }), @@ -102,12 +104,7 @@ export const highlightsAppRouter = router({ limit: z.number().optional().default(DEFAULT_NUM_HIGHLIGHTS_PER_PAGE), }), ) - .output( - z.object({ - highlights: z.array(zHighlightSchema), - nextCursor: zCursorV2.nullable(), - }), - ) + .output(zGetAllHighlightsResponseSchema) .query(async ({ input, ctx }) => { const results = await ctx.db.query.highlights.findMany({ where: and( @@ -123,6 +120,7 @@ export const highlightsAppRouter = router({ : undefined, ), limit: input.limit + 1, + orderBy: [desc(highlights.createdAt), desc(highlights.id)], }); let nextCursor: z.infer | null = null; if (results.length > input.limit) { -- cgit v1.2.3-70-g09d2