feat: update Projects component with framer-motion variants and improve animations

refactor: modify layout to use ClientOnly and BackgroundBlobsClient components

fix: correct import statement for ActivityFeed in the main page

fix: enhance sitemap fetching logic with error handling and mock support

refactor: convert BackgroundBlobs to default export for consistency

refactor: simplify ErrorBoundary component and improve error handling UI

chore: update framer-motion to version 12.24.10 in package.json and package-lock.json

test: add minimal Prisma Client mock for testing purposes

feat: create BackgroundBlobsClient for dynamic import of BackgroundBlobs

feat: implement ClientOnly component to handle client-side rendering

feat: add custom error handling components for better user experience
This commit is contained in:
2026-01-08 01:39:17 +01:00
parent c5efd28383
commit e2c2585468
27 changed files with 730 additions and 942 deletions

View File

@@ -6,12 +6,40 @@ export async function GET() {
const baseUrl = process.env.NEXT_PUBLIC_BASE_URL;
const apiUrl = `${baseUrl}/api/sitemap`; // Verwende die vollständige URL zur API
// In test runs, allow returning a mocked sitemap explicitly
if (process.env.NODE_ENV === 'test' && process.env.GHOST_MOCK_SITEMAP) {
// For tests return a simple object so tests can inspect `.body`
if (process.env.NODE_ENV === 'test') {
return { body: process.env.GHOST_MOCK_SITEMAP, headers: { "Content-Type": "application/xml" } } as any;
}
return new NextResponse(process.env.GHOST_MOCK_SITEMAP, { headers: { "Content-Type": "application/xml" } });
}
try {
// Holt die Sitemap-Daten von der API
const res = await fetch(apiUrl);
// Try global fetch first, then fall back to node-fetch
let res: any;
try {
if (typeof (globalThis as any).fetch === 'function') {
res = await (globalThis as any).fetch(apiUrl);
}
} catch (e) {
res = undefined;
}
if (!res.ok) {
console.error(`Failed to fetch sitemap: ${res.statusText}`);
if (!res || typeof res.ok === 'undefined' || !res.ok) {
try {
const mod = await import('node-fetch');
const nodeFetch = (mod as any).default ?? mod;
res = await nodeFetch(apiUrl);
} catch (err) {
console.error('Error fetching sitemap:', err);
return new NextResponse("Error fetching sitemap", {status: 500});
}
}
if (!res || !res.ok) {
console.error(`Failed to fetch sitemap: ${res?.statusText ?? 'no response'}`);
return new NextResponse("Failed to fetch sitemap", {status: 500});
}