هذا الالتزام موجود في:
2026-04-29 16:55:25 +03:00
التزام 7885be6c2e
82 ملفات معدلة مع 31672 إضافات و0 حذوفات

37
app/[lang]/page.tsx Normal file
عرض الملف

@@ -0,0 +1,37 @@
import type { Metadata } from "next";
import { notFound } from "next/navigation";
import { HomePage } from "@/components/home-page";
import { getPortfolioContent, isLanguage, languages, type Language } from "@/data/portfolio";
export function generateStaticParams() {
return languages.map((lang) => ({ lang }));
}
export function generateMetadata({ params }: { params: { lang: string } }): Metadata {
if (!isLanguage(params.lang)) {
return {};
}
const language = params.lang as Language;
const t = getPortfolioContent(language);
return {
title: t.meta.title,
description: t.meta.description,
alternates: {
canonical: `/${language}`,
languages: {
en: "/en",
ar: "/ar",
},
},
};
}
export default function LocalizedHomePage({ params }: { params: { lang: string } }) {
if (!isLanguage(params.lang)) {
notFound();
}
return <HomePage language={params.lang as Language} />;
}

عرض الملف

@@ -0,0 +1,37 @@
import type { Metadata } from "next";
import { notFound } from "next/navigation";
import { ResumePageContent } from "@/components/resume-page-content";
import { getPortfolioContent, isLanguage, languages, type Language } from "@/data/portfolio";
export function generateStaticParams() {
return languages.map((lang) => ({ lang }));
}
export function generateMetadata({ params }: { params: { lang: string } }): Metadata {
if (!isLanguage(params.lang)) {
return {};
}
const language = params.lang as Language;
const t = getPortfolioContent(language);
return {
title: language === "ar" ? `السيرة الذاتية | ${t.meta.title}` : `Resume | ${t.meta.title}`,
description: t.resume.description,
alternates: {
canonical: `/${language}/resume`,
languages: {
en: "/en/resume",
ar: "/ar/resume",
},
},
};
}
export default function LocalizedResumePage({ params }: { params: { lang: string } }) {
if (!isLanguage(params.lang)) {
notFound();
}
return <ResumePageContent language={params.lang as Language} />;
}