feat: admin panel with SQLite, auth, and calendar-style schedule editor

Complete admin panel for content management:
- SQLite database with better-sqlite3, seed script from content.ts
- Simple password auth with HMAC-signed cookies (Edge + Node compatible)
- 9 section editors: meta, hero, about, team, classes, schedule, pricing, FAQ, contact
- Team CRUD with image upload and drag reorder
- Schedule editor with Google Calendar-style visual timeline (colored blocks, overlap detection, click-to-add)
- All public components refactored to accept data props from DB (with fallback to static content)
- Middleware protecting /admin/* and /api/admin/* routes

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
2026-03-11 16:59:12 +03:00
parent d5afaf92ba
commit 27c1348f89
44 changed files with 3709 additions and 69 deletions

View File

@@ -1,8 +1,6 @@
import type { Metadata } from "next";
import { Inter, Oswald } from "next/font/google";
import { Header } from "@/components/layout/Header";
import { Footer } from "@/components/layout/Footer";
import { siteContent } from "@/data/content";
import { getContent } from "@/lib/content";
import "./globals.css";
const inter = Inter({
@@ -15,16 +13,19 @@ const oswald = Oswald({
subsets: ["latin", "cyrillic"],
});
export const metadata: Metadata = {
title: siteContent.meta.title,
description: siteContent.meta.description,
openGraph: {
title: siteContent.meta.title,
description: siteContent.meta.description,
locale: "ru_RU",
type: "website",
},
};
export function generateMetadata(): Metadata {
const { meta } = getContent();
return {
title: meta.title,
description: meta.description,
openGraph: {
title: meta.title,
description: meta.description,
locale: "ru_RU",
type: "website",
},
};
}
export default function RootLayout({
children,
@@ -36,9 +37,7 @@ export default function RootLayout({
<body
className={`${inter.variable} ${oswald.variable} surface-base font-sans antialiased`}
>
<Header />
<main>{children}</main>
<Footer />
{children}
</body>
</html>
);