Shout-out to haikei for providing an easy way to create SVG waves, blobs and other shapes. Check it out!
Create a new API endpoint:
// pages/api/og/wave.jsx
import React from "react";
import { ImageResponse } from "@vercel/og";
export const config = {
  runtime: "experimental-edge",
};
export default function handler(req) {
  try {
    const { searchParams } = new URL(req.url);
    // dynamic params
    const title = searchParams.has("title")
      ? searchParams.get("title")?.slice(0, 100)
      : "My default title";
    return new ImageResponse(
      (
        <div tw="h-full w-full flex items-start justify-start bg-yellow-50 relative">
          <h1 tw="text-7xl p-20 font-bold text-left text-gray-900">{title}</h1>
          <svg
            tw="absolute bottom-0 left-0 right-0"
            viewBox="0 0 1200 627"
            width="1200"
            height="627"
            xmlns="http://www.w3.org/2000/svg"
          >
            <path
              d="M0 513L28.5 509.8C57 506.7 114 500.3 171.2 484.5C228.3 468.7 285.7 443.3 342.8 435C400 426.7 457 435.3 514.2 447.3C571.3 459.3 628.7 474.7 685.8 490.7C743 506.7 800 523.3 857.2 522.5C914.3 521.7 971.7 503.3 1028.8 491.8C1086 480.3 1143 475.7 1171.5 473.3L1200 471L1200 628L1171.5 628C1143 628 1086 628 1028.8 628C971.7 628 914.3 628 857.2 628C800 628 743 628 685.8 628C628.7 628 571.3 628 514.2 628C457 628 400 628 342.8 628C285.7 628 228.3 628 171.2 628C114 628 57 628 28.5 628L0 628Z"
              fill="#fbbf24"
              strokeLinecap="round"
              strokeLinejoin="miter"
            ></path>
          </svg>
        </div>
      ),
      {
        width: 1200,
        height: 627,
      }
    );
  } catch (e) {
    console.log(`${e.message}`);
    return new Response(`Failed to generate the image`, {
      status: 500,
    });
  }
}You can then create new dynamic images by passing the following parameters to the API endpoint:
const title =
  "Everything you need to know about the Active Model Serializer gem";
return <img src={`/api/og/wave?title=${title}`} />;
// or
return (
  <meta
    property="og:image"
    content={`www.yourdomain.com/api/og/wave?title=${title}`}
  />
);Max 1-2x times per month.