Some checks failed
Build & Deploy / 🔍 Prepare (push) Successful in 6s
Build & Deploy / 🧪 QA (push) Successful in 2m8s
Build & Deploy / 🏗️ Build (push) Failing after 14s
Build & Deploy / 🚀 Deploy (push) Has been skipped
Build & Deploy / 🧪 Post-Deploy Verification (push) Has been skipped
Build & Deploy / 🔔 Notify (push) Successful in 1s
58 lines
1.6 KiB
TypeScript
58 lines
1.6 KiB
TypeScript
import { readFileSync } from 'fs';
|
|
import { join } from 'path';
|
|
|
|
/**
|
|
* Loads the Inter fonts for use in Satori (Next.js OG Image generation).
|
|
* Since we are using runtime = 'nodejs', we can read them from the filesystem.
|
|
*/
|
|
export async function getOgFonts() {
|
|
const boldFontPath = join(process.cwd(), 'public/fonts/Inter-Bold.woff');
|
|
const regularFontPath = join(process.cwd(), 'public/fonts/Inter-Regular.woff');
|
|
|
|
try {
|
|
console.log(`[OG] Loading fonts: bold=${boldFontPath}, regular=${regularFontPath}`);
|
|
const boldFontBuffer = readFileSync(boldFontPath);
|
|
const regularFontBuffer = readFileSync(regularFontPath);
|
|
|
|
// Satori (Vercel OG) strictly requires an ArrayBuffer, not a Node Buffer view.
|
|
const boldFont = boldFontBuffer.buffer.slice(
|
|
boldFontBuffer.byteOffset,
|
|
boldFontBuffer.byteOffset + boldFontBuffer.byteLength,
|
|
);
|
|
const regularFont = regularFontBuffer.buffer.slice(
|
|
regularFontBuffer.byteOffset,
|
|
regularFontBuffer.byteOffset + regularFontBuffer.byteLength,
|
|
);
|
|
|
|
console.log(
|
|
`[OG] Fonts loaded successfully (${boldFont.byteLength} and ${regularFont.byteLength} bytes)`,
|
|
);
|
|
|
|
return [
|
|
{
|
|
name: 'Inter',
|
|
data: boldFont,
|
|
weight: 700 as const,
|
|
style: 'normal' as const,
|
|
},
|
|
{
|
|
name: 'Inter',
|
|
data: regularFont,
|
|
weight: 400 as const,
|
|
style: 'normal' as const,
|
|
},
|
|
];
|
|
} catch (error) {
|
|
console.error(`[OG] Failed to load fonts from ${process.cwd()}:`, error);
|
|
return [];
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Common configuration for OG images
|
|
*/
|
|
export const OG_IMAGE_SIZE = {
|
|
width: 1200,
|
|
height: 630,
|
|
};
|