mirror of
https://github.com/Xevion/xevion.dev.git
synced 2026-02-01 00:26:39 -06:00
Complete architectural overhaul migrating from Directus+tRPC to Payload CMS with Next.js App Router. This represents a fundamental shift in how the application is structured and how data is managed. Major changes: - Migrated from Pages Router (src/pages/) to App Router (src/app/) - Replaced Directus CMS with Payload CMS as the content management system - Removed tRPC in favor of Payload's built-in API routes - Added PostgreSQL database via Docker Compose for local development - Implemented separate route groups for frontend and Payload admin - Updated all API routes to App Router conventions - Added Payload collections for Projects, Technologies, Links, Media, and Users - Configured ESLint for new project structure Infrastructure: - Added docker-compose.yml for PostgreSQL database - Updated environment variables for Payload CMS configuration - Integrated @payloadcms/next for seamless Next.js integration - Added GraphQL API and playground routes Dependencies: - Upgraded React from 18.2.0 to 19.2.0 - Upgraded Next.js to 15.5.6 - Added Payload CMS 3.x packages (@payloadcms/db-postgres, @payloadcms/next, etc.) - Removed Directus SDK and tRPC packages - Updated Sharp to 0.34.x - Migrated to @tanstack/react-query v5
28 lines
743 B
TypeScript
28 lines
743 B
TypeScript
/* THIS FILE WAS GENERATED AUTOMATICALLY BY PAYLOAD. */
|
|
/* DO NOT MODIFY IT BECAUSE IT COULD BE REWRITTEN AT ANY TIME. */
|
|
import type { Metadata } from "next";
|
|
|
|
import config from "../../../../payload.config";
|
|
import { RootPage, generatePageMetadata } from "@payloadcms/next/views";
|
|
import { importMap } from "../importMap";
|
|
|
|
type Args = {
|
|
params: Promise<{
|
|
segments: string[];
|
|
}>;
|
|
searchParams: Promise<{
|
|
[key: string]: string | string[];
|
|
}>;
|
|
};
|
|
|
|
export const generateMetadata = ({
|
|
params,
|
|
searchParams,
|
|
}: Args): Promise<Metadata> =>
|
|
generatePageMetadata({ config, params, searchParams });
|
|
|
|
const Page = ({ params, searchParams }: Args) =>
|
|
RootPage({ config, params, searchParams, importMap });
|
|
|
|
export default Page;
|