Comments (2)
Thank you @EyMaddis!
I created a utility function for this that could be helpful for others who find this issue:
import { ImageResponse } from "@vercel/og";
import type { NextApiResponse } from "next";
export default async function renderOgImageResponse(
res: NextApiResponse,
component: JSX.Element
) {
const imgRes = new ImageResponse(component, {
width: 1200,
height: 630,
});
// vercels types are wrong
const i = imgRes as Response;
// I tried getting the streams API to work, but failed, so we need to use full buffers
const b = await i.blob();
res.setHeader("content-type", b.type);
res.setHeader("content-length", b.size);
res.setHeader(
"cache-control",
process.env.NODE_ENV === "development"
? "no-cache, no-store"
: "public, immutable, no-transform, max-age=31536000"
);
res.status(200);
const arrayBuffer = await b.arrayBuffer();
res.send(Buffer.from(arrayBuffer));
}
And then in your Nextjs API routes, you can use it like this:
import type { NextApiRequest, NextApiResponse } from "next";
import renderOgImageResponse from "@/server/utils/og-render";
export default async function handler(
_req: NextApiRequest,
res: NextApiResponse
) {
return renderOgImageResponse(res, <OGImageRenderer />);
}
const OGImageRenderer = () => {
return (
<div
style={{
width: "100%",
height: "100%",
display: "flex",
alignItems: "center",
justifyContent: "center",
fontSize: 128,
background: "lavender",
}}
>
Hello world!
</div>
);
};
from og.
Hey @EyMaddis thanks for bringing it up! I wouldn't say it's a bad idea but I haven't seen any announcement/changelog from Vercel and I'm guessing they might break the API before announcing this Node.js support. If you don't mind the few extra lines / type casts, I believe you will be fine with @vercel/og
from og.
Related Issues (2)
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from og.