feat: breadcrumbs for My Pages

This commit is contained in:
Simon Emanuelsson
2024-04-11 18:51:38 +02:00
parent 33b4d1d9fc
commit 38f764e0ff
31 changed files with 228 additions and 87 deletions

View File

@@ -0,0 +1,5 @@
import { mergeRouters } from "@/server/trpc"
import { breadcrumbsQueryRouter } from "./query"
export const breadcrumbsRouter = mergeRouters(breadcrumbsQueryRouter)

View File

@@ -0,0 +1,8 @@
import { z } from "zod"
export const getBreadcrumbsSchema = z.array(
z.object({
href: z.string().optional(),
title: z.string(),
})
)

View File

@@ -0,0 +1,43 @@
import { z } from "zod"
import { badRequestError } from "@/server/errors/trpc"
import { getBreadcrumbsSchema } from "./output"
import { publicProcedure, router } from "@/server/trpc"
const rootMyPagesBreadcrumb = {
href: "/en/my-pages",
title: "My Pages",
}
enum paths {
"/my-pages",
"/my-pages/benefits",
"/my-pages/overview",
"/my-pages/profile",
}
const keys = Object.keys(paths) as [keyof typeof paths]
const possibleBreadcrumbs: Record<string, { title: string; href?: string }[]> =
{
"/my-pages": [
{
title: rootMyPagesBreadcrumb.title,
},
],
"/my-pages/benefits": [rootMyPagesBreadcrumb, { title: "Benefits" }],
"/my-pages/overview": [rootMyPagesBreadcrumb, { title: "Overview" }],
"/my-pages/profile": [rootMyPagesBreadcrumb, { title: "Profile" }],
}
export const breadcrumbsQueryRouter = router({
get: publicProcedure.input(z.object({ href: z.enum(keys) })).query((opts) => {
const breadcrumbs = possibleBreadcrumbs[opts.input.href]
const validatedBreadcrumbs = getBreadcrumbsSchema.safeParse(breadcrumbs)
if (validatedBreadcrumbs.success) {
return breadcrumbs
}
throw badRequestError()
}),
})

View File

@@ -0,0 +1,7 @@
import { router } from "@/server/trpc"
import { breadcrumbsRouter } from "./breadcrumbs"
export const contentstackRouter = router({
breadcrumbs: breadcrumbsRouter,
})