feat: add announcements feature with dynamic routing and markdown support

This commit is contained in:
2026-03-29 05:01:23 +00:00
parent b23a3f41f3
commit 64f3787b4e
8 changed files with 419 additions and 21 deletions

View File

@@ -0,0 +1,49 @@
import Link from "next/link";
import { Badge } from "@/components/ui/badge";
import { Card, CardContent, CardHeader, CardTitle } from "@/components/ui/card";
import { getAllAnnouncements } from "@/lib/announcements";
export const metadata = {
title: "お知らせ | Takasumi-Neodyマイクラサーバプロジェクト",
description: "Takasumi-Neodyマイクラサーバプロジェクトのお知らせ一覧です。",
};
export default async function AnnouncementsPage() {
const announcements = await getAllAnnouncements();
return (
<div className="mx-auto flex w-full max-w-5xl flex-1 flex-col gap-6 px-4 py-8 sm:px-8 sm:py-12">
<header className="rounded-3xl border bg-card/70 p-6 shadow-sm backdrop-blur sm:p-8">
<Badge variant="outline" className="mb-3">
</Badge>
<h1 className="text-3xl font-semibold tracking-tight sm:text-4xl"></h1>
<p className="mt-3 text-sm leading-7 text-muted-foreground sm:text-base">
Markdown
</p>
</header>
<section className="grid gap-4">
{announcements.map((item) => (
<Card key={item.slug} className="border-foreground/10">
<CardHeader>
<p className="text-xs text-muted-foreground">{item.date}</p>
<CardTitle className="text-xl">
<Link
href={`/announcements/${item.slug}`}
className="underline-offset-4 hover:underline"
>
{item.title}
</Link>
</CardTitle>
</CardHeader>
<CardContent>
<p className="text-sm text-muted-foreground">{item.summary}</p>
</CardContent>
</Card>
))}
</section>
</div>
);
}