Rocky_Mountain_Vending/.pnpm-store/v10/files/72/44e1d30f7be289a38951fe2f5adcbab8ce6465a7547192494546fd02c221d3769d65e637b7381a4a9c6ee05a1bfc055ab5a8c8477c4df4dd18346e54b4a853
DMleadgen 46d973904b
Initial commit: Rocky Mountain Vending website
Next.js website for Rocky Mountain Vending company featuring:
- Product catalog with Stripe integration
- Service areas and parts pages
- Admin dashboard with Clerk authentication
- SEO optimized pages with JSON-LD structured data

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-02-12 16:22:15 -07:00

48 lines
No EOL
2 KiB
Text

function importModule() {
return import(process.env.NEXT_RUNTIME === 'edge' ? 'next/dist/compiled/@vercel/og/index.edge.js' : 'next/dist/compiled/@vercel/og/index.node.js');
}
/**
* The ImageResponse class allows you to generate dynamic images using JSX and CSS.
* This is useful for generating social media images such as Open Graph images, Twitter cards, and more.
*
* Read more: [Next.js Docs: `ImageResponse`](https://nextjs.org/docs/app/api-reference/functions/image-response)
*/ export class ImageResponse extends Response {
static #_ = this.displayName = 'ImageResponse';
constructor(...args){
const readable = new ReadableStream({
async start (controller) {
const OGImageResponse = // So far we have to manually determine which build to use,
// as the auto resolving is not working
(await importModule()).ImageResponse;
const imageResponse = new OGImageResponse(...args);
if (!imageResponse.body) {
return controller.close();
}
const reader = imageResponse.body.getReader();
while(true){
const { done, value } = await reader.read();
if (done) {
return controller.close();
}
controller.enqueue(value);
}
}
});
const options = args[1] || {};
const headers = new Headers({
'content-type': 'image/png',
'cache-control': process.env.NODE_ENV === 'development' ? 'no-cache, no-store' : 'public, max-age=0, must-revalidate'
});
if (options.headers) {
const newHeaders = new Headers(options.headers);
newHeaders.forEach((value, key)=>headers.set(key, value));
}
super(readable, {
headers,
status: options.status,
statusText: options.statusText
});
}
}
//# sourceMappingURL=image-response.js.map