refactor: create page specific tRPC requests
This commit is contained in:
@@ -8,10 +8,11 @@ import type { LangParams, PageArgs } from "@/types/params"
|
|||||||
|
|
||||||
export default async function BenefitsPage({ params }: PageArgs<LangParams>) {
|
export default async function BenefitsPage({ params }: PageArgs<LangParams>) {
|
||||||
const user = await serverClient().user.get()
|
const user = await serverClient().user.get()
|
||||||
const accountPage = await serverClient().contentstack.accountPage.get({
|
const accountPage = await serverClient().contentstack.accountPage.getBenefits(
|
||||||
lang: params.lang,
|
{
|
||||||
uri: "/my-pages/benefits",
|
lang: params.lang,
|
||||||
})
|
}
|
||||||
|
)
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<main className={styles.container}>
|
<main className={styles.container}>
|
||||||
|
|||||||
@@ -10,10 +10,11 @@ import type { LangParams, PageArgs } from "@/types/params"
|
|||||||
|
|
||||||
export default async function MyPageOverview({ params }: PageArgs<LangParams>) {
|
export default async function MyPageOverview({ params }: PageArgs<LangParams>) {
|
||||||
const user = await serverClient().user.get()
|
const user = await serverClient().user.get()
|
||||||
const accountPage = await serverClient().contentstack.accountPage.get({
|
const accountPage = await serverClient().contentstack.accountPage.getOverview(
|
||||||
uri: "/my-pages/overview",
|
{
|
||||||
lang: params.lang,
|
lang: params.lang,
|
||||||
})
|
}
|
||||||
|
)
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<MaxWidth className={styles.blocks} tag="main">
|
<MaxWidth className={styles.blocks} tag="main">
|
||||||
|
|||||||
@@ -6,17 +6,38 @@ import { Lang } from "@/constants/languages"
|
|||||||
import GetAccountPage from "@/lib/graphql/Query/AccountPage.graphql"
|
import GetAccountPage from "@/lib/graphql/Query/AccountPage.graphql"
|
||||||
import type { GetAccountPageData } from "@/types/requests/myPages/accountpage"
|
import type { GetAccountPageData } from "@/types/requests/myPages/accountpage"
|
||||||
export const accountPageQueryRouter = router({
|
export const accountPageQueryRouter = router({
|
||||||
get: publicProcedure
|
getOverview: publicProcedure
|
||||||
.input(z.object({ uri: z.string(), lang: z.nativeEnum(Lang) }))
|
.input(z.object({ lang: z.nativeEnum(Lang) }))
|
||||||
.query(async ({ input }) => {
|
.query(async ({ input }) => {
|
||||||
|
const url = "/my-pages/overview"
|
||||||
const accountPage = await request<GetAccountPageData>(
|
const accountPage = await request<GetAccountPageData>(
|
||||||
GetAccountPage,
|
GetAccountPage,
|
||||||
{
|
{
|
||||||
locale: input.lang,
|
locale: input.lang,
|
||||||
url: input.uri,
|
url,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
tags: [`${input.uri}-${input.lang}`],
|
tags: [`${url}-${input.lang}`],
|
||||||
|
}
|
||||||
|
)
|
||||||
|
if (accountPage.data && accountPage.data.all_account_page.total) {
|
||||||
|
return accountPage.data.all_account_page.items[0]
|
||||||
|
}
|
||||||
|
|
||||||
|
throw badRequestError()
|
||||||
|
}),
|
||||||
|
getBenefits: publicProcedure
|
||||||
|
.input(z.object({ lang: z.nativeEnum(Lang) }))
|
||||||
|
.query(async ({ input }) => {
|
||||||
|
const url = "/my-pages/overview"
|
||||||
|
const accountPage = await request<GetAccountPageData>(
|
||||||
|
GetAccountPage,
|
||||||
|
{
|
||||||
|
locale: input.lang,
|
||||||
|
url,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
tags: [`${url}-${input.lang}`],
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
if (accountPage.data && accountPage.data.all_account_page.total) {
|
if (accountPage.data && accountPage.data.all_account_page.total) {
|
||||||
|
|||||||
Reference in New Issue
Block a user