import { getPhotosCached } from '@/photo/cache'; import { GRID_OG_DIMENSION, MAX_PHOTOS_TO_SHOW_TEMPLATE, } from '@/image-response'; import TemplateImageResponse from '@/image-response/TemplateImageResponse'; import { getIBMPlexMono } from '@/app/font'; import { ImageResponse } from 'next/og'; import { getImageResponseCacheControlHeaders } from '@/image-response/cache'; import { isNextImageReadyBasedOnPhotos } from '@/photo'; export async function GET() { const [ photos, { fontFamily, fonts }, headers, ] = await Promise.all([ getPhotosCached({ sortBy: 'priority', limit: MAX_PHOTOS_TO_SHOW_TEMPLATE, }).catch(() => []), getIBMPlexMono(), getImageResponseCacheControlHeaders(), ]); const { width, height } = GRID_OG_DIMENSION; // Make sure next/image can be reached from absolute urls, // which may not exist on first pre-render const isNextImageReady = await isNextImageReadyBasedOnPhotos(photos); return new ImageResponse( ( ), { width, height, fonts, headers }, ); }