100 lines
3.3 KiB
TypeScript
Raw Permalink Normal View History

2025-09-16 17:19:58 +08:00
import type { Metadata } from 'next';
import { getSEOConfig } from '../../../lib/seo-config';
import NewsPageWrapper from '../../components/news/NewsPageWrapper';
// 静态生成时获取文章数据
async function getStaticNewsData(locale: string) {
// 检查是否为静态导出模式
const isStaticMode = process.env.BUILD_MODE === 'static';
if (isStaticMode) {
try {
const { getStaticArticles, getStaticCategories } = await import('../../../lib/static-data');
const mappedLocale = locale === 'zh' ? 'zh-CN' : locale as 'zh-CN' | 'zh-TW' | 'en';
const articles = getStaticArticles(mappedLocale);
const categories = getStaticCategories(mappedLocale);
console.log(`[Static Build] Loaded ${articles.length} articles for locale ${mappedLocale}`);
return { articles, categories };
} catch (error) {
console.error('Error loading static data:', error);
return { articles: [], categories: [] };
}
}
// 在开发模式或运行时模式返回null让客户端组件自己获取数据
return null;
}
// Generate static params for supported locales
export async function generateStaticParams() {
return [
{ locale: 'zh' },
{ locale: 'zh-CN' },
{ locale: 'zh-TW' },
{ locale: 'en' },
];
}
// Generate metadata for the news page
export async function generateMetadata({
params: { locale },
}: {
params: { locale: string };
}): Promise<Metadata> {
const language = locale === 'zh' ? 'zh-CN' : locale === 'zh-CN' ? 'zh-CN' : locale === 'zh-TW' ? 'zh-TW' : 'en';
const seo = getSEOConfig('news', language);
return {
title: seo.title,
description: seo.description,
keywords: seo.keywords,
openGraph: {
title: seo.openGraph?.title,
description: seo.openGraph?.description,
type: seo.openGraph?.type as any,
images: seo.openGraph?.images,
},
twitter: {
card: seo.twitter?.card as any,
title: seo.twitter?.title,
description: seo.twitter?.description,
images: seo.twitter?.images,
},
alternates: {
canonical: locale === 'zh' ? '/news' : `/${locale}/news`,
languages: {
'zh-CN': '/news',
'zh-TW': '/zh-TW/news',
en: '/en/news',
},
},
};
}
export default async function NewsPage({ params: { locale } }: { params: { locale: string } }) {
// 获取静态数据(如果是静态模式)
const staticData = await getStaticNewsData(locale);
// 在静态模式下,确保数据被正确传递
if (staticData) {
console.log(`[NewsPage] Passing ${staticData.articles.length} articles to wrapper component`);
}
return (
<>
{/* 将数据序列化为JSON并嵌入页面供客户端组件使用 */}
{staticData && (
<script
id="initial-news-data"
type="application/json"
dangerouslySetInnerHTML={{
__html: JSON.stringify(staticData)
}}
/>
)}
<NewsPageWrapper locale={locale} initialData={staticData} />
</>
);
}