52 lines
1.6 KiB
TypeScript
52 lines
1.6 KiB
TypeScript
import { NextResponse } from "next/server"
|
|
|
|
import { findLang } from "@/constants/languages"
|
|
|
|
import { getContentTypeByPathName, PageTypeEnum } from "@/utils/contentType"
|
|
|
|
import type { NextMiddleware } from "next/server"
|
|
|
|
import { MiddlewareMatcher } from "@/types/middleware"
|
|
|
|
export const middleware: NextMiddleware = async (request) => {
|
|
const { nextUrl } = request
|
|
const lang = findLang(nextUrl.pathname)
|
|
|
|
const pathNameWithoutLang = nextUrl.pathname.replace(`/${lang}`, "")
|
|
const searchParams = new URLSearchParams(request.nextUrl.searchParams)
|
|
|
|
const contentType = await getContentTypeByPathName(pathNameWithoutLang, lang)
|
|
|
|
if (request.nextUrl.pathname.includes("preview")) {
|
|
searchParams.set("uri", pathNameWithoutLang.replace("/preview", ""))
|
|
return NextResponse.rewrite(
|
|
new URL(`/${lang}/preview-current?${searchParams.toString()}`, nextUrl)
|
|
)
|
|
}
|
|
|
|
searchParams.set("uri", pathNameWithoutLang)
|
|
switch (contentType) {
|
|
case PageTypeEnum.CurrentBlocksPage:
|
|
return NextResponse.rewrite(
|
|
new URL(
|
|
`/${lang}/current-content-page?${searchParams.toString()}`,
|
|
nextUrl
|
|
)
|
|
)
|
|
case PageTypeEnum.LoyaltyPage:
|
|
return NextResponse.rewrite(
|
|
new URL(`/${lang}/loyalty-page?${searchParams.toString()}`, nextUrl)
|
|
)
|
|
// case PageTypeEnum.ContentPage:
|
|
// return NextResponse.rewrite(
|
|
// new URL(`/${lang}/content-page?${searchParams.toString()}`, nextUrl)
|
|
// )
|
|
default:
|
|
return NextResponse.next()
|
|
}
|
|
}
|
|
|
|
export const matcher: MiddlewareMatcher = (request) => {
|
|
return true
|
|
}
|