import { ImageResponse } from '@vercel/og';
import { NextRequest } from 'next/server';

export const runtime = 'edge';

const interRegular = fetch(new URL('./Inter-Regular.ttf', import.meta.url)).then((res) =>
  res.arrayBuffer()
);

const interBold = fetch(new URL('./Inter-Bold.ttf', import.meta.url)).then((res) =>
  res.arrayBuffer()
);

export async function GET(req: NextRequest): Promise<Response | ImageResponse> {
  try {
    const [regularFont, boldFont] = await Promise.all([interRegular, interBold]);

    const { searchParams } = new URL(req.url);

    const title = searchParams.has('title')
      ? searchParams.get('title')?.slice(0, 100)
      : process.env.SITE_NAME;

    return new ImageResponse(
      (
        <div tw="flex h-full w-full flex-col items-center justify-center bg-black">
          <svg viewBox="0 0 32 32" width="140">
            <rect width="100%" height="100%" rx="16" fill="white" />
            <path
              fillRule="evenodd"
              clipRule="evenodd"
              fill="black"
              d="M17.6482 10.1305L15.8785 7.02583L7.02979 22.5499H10.5278L17.6482 10.1305ZM19.8798 14.0457L18.11 17.1983L19.394 19.4511H16.8453L15.1056 22.5499H24.7272L19.8798 14.0457Z"
            />
          </svg>

          <div tw="mt-12 text-6xl text-white font-bold">{title}</div>
        </div>
      ),
      {
        width: 1200,
        height: 630,
        fonts: [
          {
            name: 'Inter',
            data: regularFont,
            style: 'normal',
            weight: 400
          },
          {
            name: 'Inter',
            data: boldFont,
            style: 'normal',
            weight: 700
          }
        ]
      }
    );
  } catch (e) {
    if (!(e instanceof Error)) throw e;

    console.log(e.message);
    return new Response(`Failed to generate the image`, {
      status: 500
    });
  }
}