-
Notifications
You must be signed in to change notification settings - Fork 27.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[NEXT-1204] opengraph-image
can't be used to accept params in catch-all routes (Error: Catch-all must be the last part of the URL.
)
#49630
Comments
I was able to accomplish this with a workaround, albeit a bit hacky. My directory format was So, I moved from (It also worked with I ended up with this workaround.
const nextConfig = {
async rewrites() {
return {
afterFiles: [
{
source: "/:path([^.|company]*)*",
destination: "/?path=:path*",
missing: [
{
type: "query",
key: "path",
},
],
},
],
}
},
} There are possibly two other bugs here - which I'll open separately.
|
opengraph-image
can't be used to accept params in catch-all routes (Error: Catch-all must be the last part of the URL.
)opengraph-image
can't be used to accept params in catch-all routes (Error: Catch-all must be the last part of the URL.
)
Does the solution in #48162 (comment) work for you? For now as it has to work as a route and receive params, it can't stay under a catch all routes. |
With I ended up refactoring the code to split out the params individually to work around this for now: import { ImageResponse } from "next/server"
import { getData } from "@/lib/queries" // uses vercel/postgres
export const alt = "Hi there!"
export const size = {
width: 1200,
height: 630,
}
export const contentType = "image/png"
export const runtime = "edge"
export default async function handler({
params,
}: {
params: { slug: string; }
}) {
if (!params || !params.slug || !params.code) {
return
}
const { slug, code } = params
//
// just a sql query under the hood
// using vercel/postgres (Edge-capable)
//
// note:
// `code` is a hash for protected posts.
//
const post = await getData(slug, code)
const fontBold = await fetch(
new URL("sans-extrabold.ttf", import.meta.url)
).then((response) => response.arrayBuffer())
const fontMedium = await fetch(
new URL("sans-medium.ttf", import.meta.url)
).then((response) => response.arrayBuffer())
return new ImageResponse(
(
<div
style={{
background: "#f1f5f9",
width: "100%",
height: "100%",
display: "flex",
alignItems: "stretch",
}}>
<div
style={{
flexGrow: 1,
borderRadius: "1rem",
padding: "2rem",
background: "#ffffff",
display: "flex",
flexDirection: "column",
margin: "4rem",
}}>
<h1 tw="text-7xl font-bold text-red-800 mb-8">{post?.title}</h1>
<p tw="text-5xl font-bold text-slate-900 mb-12">
{post?.excerpt}
</p>
</div>
),
{
...size,
fonts: [
{
name: "Bold",
data: fontBold,
style: "normal",
weight: 700,
},
{
name: "Bold",
data: fontMedium,
style: "normal",
weight: 400,
},
],
}
)
} |
nice, that seemed to work well for me! |
Going to close now as the catch-all routes is catching all the sub routes including metadata ones so not possible to match them and forward the |
@mbahArip do you mind sharing the code inside the opengraph/[...slug]/route.tsx, I did the implementation you suggested but for me is not reaching the return image code, probably doing something slightly different, just not sure what |
you can check the code here |
This closed issue has been automatically locked because it had no new activity for a month. If you are running into a similar issue, please create a new issue with the steps to reproduce. Thank you. |
Verify canary release
Provide environment information
Operating System: Platform: darwin Arch: arm64 Version: Darwin Kernel Version 22.4.0: Mon Mar 6 20:59:28 PST 2023; root:xnu-8796.101.5~3/RELEASE_ARM64_T6000 Binaries: Node: 20.1.0 npm: 9.6.4 Yarn: N/A pnpm: 8.5.0 Relevant packages: next: 13.4.1 eslint-config-next: 13.4.1 react: 18.2.0 react-dom: 18.2.0
Which area(s) of Next.js are affected? (leave empty if unsure)
App directory (appDir: true), Metadata (metadata, generateMetadata, next/head, head.js), Middleware / Edge (API routes, runtime)
Link to the code that reproduces this issue
#48162
To Reproduce
I am trying to use
opengraph-image.tsx
inside of./app/[[...path]]
but get theError: Catch-all must be the last part of the URL.
message.I saw a similar issue that was recently closed: #48162 - however I am trying to use the params to construct the image:
I wasn't sure based on the discussion in the related issue if this was WAI or slated for a future fix, so wanted to surface it in my case, where I needed to accept params. Thanks!
Describe the Bug
Cannot use opengraph-image inside of a [[...catchAll]] route; error is: Error: Catch-all must be the last part of the URL.
Expected Behavior
This functionality is allowed
Which browser are you using? (if relevant)
No response
How are you deploying your application? (if relevant)
No response
NEXT-1204
The text was updated successfully, but these errors were encountered: