import { ImageResponse } from '@vercel/og' import { NextRequest } from 'next/server' export const config = { runtime: 'experimental-edge', } export default function handler(req: NextRequest) { try { const { searchParams } = new URL(req.url) // ?title= const hasTitle = searchParams.has('title') const title = hasTitle ? searchParams.get('title')?.slice(0, 100) : 'My default title' return new ImageResponse( ( <div style={{ backgroundColor: 'black', backgroundSize: '150px 150px', height: '100%', width: '100%', display: 'flex', textAlign: 'center', alignItems: 'center', justifyContent: 'center', flexDirection: 'column', flexWrap: 'nowrap', }} > <div style={{ display: 'flex', alignItems: 'center', alignContent: 'center', justifyContent: 'center', justifyItems: 'center', }} > {/* eslint-disable-next-line @next/next/no-img-element */} <img alt="Vercel" height={200} src="data:image/svg+xml,%3Csvg width='116' height='100' fill='white' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M57.5 0L115 100H0L57.5 0z' /%3E%3C/svg%3E" style={{ margin: '0 30px' }} width={232} /> </div> <div style={{ fontSize: 60, fontStyle: 'normal', letterSpacing: '-0.025em', color: 'white', marginTop: 30, padding: '0 120px', lineHeight: 1.4, whiteSpace: 'pre-wrap', }} > {title} </div> </div> ), { width: 1200, height: 630, } ) } catch (e: any) { console.log(`${e.message}`) return new Response(`Failed to generate the image`, { status: 500, }) } }