feat: move overview page query to tRPC request

This commit is contained in:
Arvid Norlin
2024-04-18 14:45:55 +02:00
parent ed2cc59a87
commit c8cb832350
6 changed files with 139 additions and 93 deletions

View File

@@ -0,0 +1,3 @@
import { mergeRouters } from "@/server/trpc"
import { accountPageQueryRouter } from "./query"
export const accountPageRouter = mergeRouters(accountPageQueryRouter)

View File

@@ -0,0 +1,28 @@
import { z } from "zod"
import { badRequestError } from "@/server/errors/trpc"
import { publicProcedure, router } from "@/server/trpc"
import { request } from "@/lib/graphql/request"
import { Lang } from "@/constants/languages"
import GetAccountPage from "@/lib/graphql/Query/AccountPage.graphql"
import type { GetAccountPageData } from "@/types/requests/myPages/accountpage"
export const accountPageQueryRouter = router({
get: publicProcedure
.input(z.object({ uri: z.string(), lang: z.nativeEnum(Lang) }))
.query(async ({ input }) => {
const accountPage = await request<GetAccountPageData>(
GetAccountPage,
{
locale: input.lang,
url: input.uri,
},
{
tags: [`${input.uri}-${input.lang}`],
}
)
if (accountPage.data && accountPage.data.all_account_page.total) {
return accountPage.data.all_account_page.items[0]
}
throw badRequestError()
}),
})

View File

@@ -1,5 +1,6 @@
import { router } from "@/server/trpc"
import { accountPageRouter } from "./accountPage"
import { breadcrumbsRouter } from "./breadcrumbs"
import { contactConfigRouter } from "./contactConfig"
import { loyaltyPageRouter } from "./loyaltyPage"
@@ -7,5 +8,6 @@ import { loyaltyPageRouter } from "./loyaltyPage"
export const contentstackRouter = router({
breadcrumbs: breadcrumbsRouter,
loyaltyPage: loyaltyPageRouter,
accountPage: accountPageRouter,
contactConfig: contactConfigRouter,
})