-
Notifications
You must be signed in to change notification settings - Fork 4
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
DIGG-512: Initital update to update paths to readable url
- Loading branch information
1 parent
affd5b7
commit 4fce91f
Showing
31 changed files
with
854 additions
and
323 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
import { NextResponse } from "next/server"; | ||
import type { NextRequest } from "next/server"; | ||
|
||
import i18n from "./i18n"; | ||
|
||
function getLocale(request: NextRequest): string { | ||
const acceptLanguage = request.headers.get("accept-language"); | ||
if (acceptLanguage) { | ||
const [browserLocale] = acceptLanguage.split(","); | ||
if (i18n.locales.includes(browserLocale as string)) { | ||
return browserLocale; | ||
} | ||
} | ||
return i18n.defaultLocale; | ||
} | ||
|
||
export function middleware(request: NextRequest) { | ||
const pathname = request.nextUrl.pathname; | ||
|
||
// Check if the pathname already has a locale | ||
const pathnameHasLocale = i18n.locales.some( | ||
(locale) => pathname.startsWith(`/${locale}/`) || pathname === `/${locale}`, | ||
); | ||
|
||
if (pathnameHasLocale) { | ||
// If it's the default locale, redirect to remove it from URL | ||
if (pathname.startsWith(`/${i18n.defaultLocale}/`)) { | ||
const newPathname = pathname.replace(`/${i18n.defaultLocale}`, "") || "/"; | ||
const newUrl = new URL(newPathname, request.url); | ||
newUrl.search = request.nextUrl.search; | ||
return NextResponse.redirect(newUrl); | ||
} | ||
return NextResponse.next(); | ||
} | ||
|
||
const locale = getLocale(request); | ||
|
||
// Only add locale to URL if it's not the default locale | ||
if (locale !== i18n.defaultLocale) { | ||
const newUrl = new URL(`/${locale}${pathname}`, request.url); | ||
newUrl.search = request.nextUrl.search; | ||
return NextResponse.redirect(newUrl); | ||
} | ||
|
||
// For default locale, just continue without modification | ||
return NextResponse.next(); | ||
} | ||
|
||
export const config = { | ||
matcher: [ | ||
"/((?!api|_next/static|_next/image|favicon.ico|__ENV.js|manifest.json|.*\\.(?:jpg|jpeg|gif|png|svg|woff|woff2)).*)", | ||
"/", | ||
], | ||
}; |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
import { NextApiRequest, NextApiResponse } from "next"; | ||
|
||
import { handleEntryStoreRedirect } from "@/utilities/entrystore/entrystore-redirect"; | ||
|
||
export default async function handler( | ||
req: NextApiRequest, | ||
res: NextApiResponse, | ||
) { | ||
const { config, resourceUri, locale, isSandbox } = req.body; | ||
|
||
try { | ||
const result = await handleEntryStoreRedirect( | ||
config, | ||
locale, | ||
isSandbox, | ||
resourceUri, | ||
); | ||
|
||
if (result.notFound) { | ||
return res.status(404).json(result); | ||
} else { | ||
return res.status(200).json(result); | ||
} | ||
} catch (error) { | ||
console.error(error); | ||
return res.status(500).json({ error: "Internal Server Error" }); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,19 +1,54 @@ | ||
import { GetServerSidePropsContext } from "next/types"; | ||
import { useRouter } from "next/router"; | ||
import { useContext, useEffect, useState } from "react"; | ||
|
||
import { handleEntryStoreRedirect } from "@/utilities/entrystore/entrystore-redirect"; | ||
import { ConceptPage } from "@/features/entryscape/concept-page"; | ||
import { EntrystoreProvider } from "@/providers/entrystore-provider"; | ||
import { SettingsContext } from "@/providers/settings-provider"; | ||
import { getEntryStoreProps } from "@/utilities/entrystore/get-entrystore-props"; | ||
|
||
export default function Concept() { | ||
return null; | ||
} | ||
const { env } = useContext(SettingsContext); | ||
const router = useRouter(); | ||
const { concept, param } = router.query || {}; | ||
const [resourceUri, setResourceUri] = useState<string | null>(null); | ||
|
||
useEffect(() => { | ||
const fetchEntryStoreProps = async () => { | ||
if (!concept || !param) return; | ||
const isSandbox = window.location.host.includes("sandbox"); | ||
|
||
const data = await getEntryStoreProps({ | ||
config: { | ||
pathPrefix: "/concepts", | ||
redirectPath: "/concepts", | ||
entrystorePathKey: "ENTRYSCAPE_TERMS_PATH", | ||
param: concept, | ||
secondParam: param as string, | ||
}, | ||
locale: router.locale || "sv", | ||
isSandbox, | ||
router, | ||
includeBasePath: false, | ||
}); | ||
|
||
if (data?.resourceUri) { | ||
setResourceUri(data.resourceUri); | ||
} | ||
}; | ||
|
||
export const getServerSideProps = async ( | ||
context: GetServerSidePropsContext, | ||
) => { | ||
return handleEntryStoreRedirect(context, { | ||
pathPrefix: "/concepts", | ||
redirectPath: "/concepts", | ||
entrystorePathKey: "ENTRYSCAPE_TERMS_PATH", | ||
paramName: "concept", | ||
secondParamName: "param", | ||
}); | ||
}; | ||
fetchEntryStoreProps(); | ||
}, [concept, param]); | ||
|
||
if (!resourceUri) return null; | ||
|
||
return ( | ||
<EntrystoreProvider | ||
env={env} | ||
rUri={resourceUri} | ||
entrystoreUrl={env.ENTRYSCAPE_TERMS_PATH} | ||
pageType="concept" | ||
> | ||
<ConceptPage /> | ||
</EntrystoreProvider> | ||
); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.