import { getPhotosCached } from '@/photo/cache'; import { IMAGE_OG_DIMENSION_SMALL, MAX_PHOTOS_TO_SHOW_PER_TAG, } from '@/image-response'; import FilmSimulationImageResponse from '@/image-response/FilmSimulationImageResponse'; import { FilmSimulation } from '@/simulation'; import { getIBMPlexMonoMedium } from '@/app/font'; import { ImageResponse } from 'next/og'; import { getImageResponseCacheControlHeaders } from '@/image-response/cache'; import { GENERATE_STATIC_PARAMS_LIMIT } from '@/photo/db'; import { getUniqueFilmSimulations } from '@/photo/db/query'; import { STATICALLY_OPTIMIZED_PHOTO_CATEGORY_OG_IMAGES, IS_PRODUCTION, } from '@/app/config'; export let generateStaticParams: (() => Promise<{ simulation: FilmSimulation }[]>) | undefined = undefined; if (STATICALLY_OPTIMIZED_PHOTO_CATEGORY_OG_IMAGES && IS_PRODUCTION) { generateStaticParams = async () => { const simulations = await getUniqueFilmSimulations(); return simulations .slice(0, GENERATE_STATIC_PARAMS_LIMIT) .map(({ simulation }) => ({ simulation })); }; } export async function GET( _: Request, context: { params: Promise<{ simulation: FilmSimulation }> }, ) { const { simulation } = await context.params; const [ photos, { fontFamily, fonts }, headers, ] = await Promise.all([ getPhotosCached({ limit: MAX_PHOTOS_TO_SHOW_PER_TAG, simulation }), getIBMPlexMonoMedium(), getImageResponseCacheControlHeaders(), ]); const { width, height } = IMAGE_OG_DIMENSION_SMALL; return new ImageResponse( , { width, height, fonts, headers }, ); }