Redirects

Handling redirects from the Redirect module.


This guide uses `translatedPathFromContext` which is available in `next-drupal ^1.1.0`.

Next.js

To use redirects in Next.js you can configure a `redirects` key in `next.config.js`.

next.config.js

module.exports = {
async redirects() {
return [
{
source: "/about",
destination: "/",
permanent: true,
},
]
},
}

Redirect Module

To handle redirects coming from Drupal (redirect module), you can use `translatedPathFromContext`.

Here's how you can handle redirect in `getStaticProps`.

pages/[...slug].tsx

import {
DrupalNode,
getPathsFromContext,
getResourceFromContext,
getView,
translatePathFromContext,
} from "next-drupal"
export async function getStaticProps(
context
): Promise<GetStaticPropsResult<NodePageProps>> {
// Get information about the path.
const path = await translatePathFromContext(context)
if (!path) {
return {
notFound: true,
}
}
// Check for redirect.
if (path.redirect?.length) {
const [redirect] = path.redirect
return {
redirect: {
destination: redirect.to,
permanent: redirect.status === "301",
},
}
}
// No redirect. Fetch the resource for this type.
const type = path.jsonapi.resourceName
const resource = await getResourceFromContext<DrupalNode>(type, context)
}

With `fallback: "blocking"` in `getStaticPaths`, this will cache and handle redirects configured in Drupal and still work with incremental static regeneration.

In multilingual setup you may need to specify `pathPrefix` option for `translatePathFromContext` for default locale. In some cases Drupal can't find a matching redirect for path without explicit locale prefix.

// Get information about the path.
const path = await drupal.translatePathFromContext(context, {
pathPrefix: context.locale === context.defaultLocale ? context.locale : "/",
})