feat(blog): add file-based blog with dynamic slugs, MDX content and layout shell
- Introduced blog routing using Next.js App Router - Implemented dynamic [slug] pages for blog posts - Added MDX-based content loading via lib/posts - Integrated shared TopBar layout with navigation - Established clear content, lib and component separation
This commit is contained in:
53
apps/public-web/node_modules/next/dist/server/og/image-response.js
generated
vendored
Normal file
53
apps/public-web/node_modules/next/dist/server/og/image-response.js
generated
vendored
Normal file
@@ -0,0 +1,53 @@
|
||||
"use strict";
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
Object.defineProperty(exports, "ImageResponse", {
|
||||
enumerable: true,
|
||||
get: function() {
|
||||
return ImageResponse;
|
||||
}
|
||||
});
|
||||
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');
|
||||
}
|
||||
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
|
||||
Reference in New Issue
Block a user