9e45780ba0
First commit of the Next.js community site that powers deepseek-tui.com, deployed via Cloudflare Workers / OpenNext. This commit lands the scaffold and applies the visual + correctness pass requested by community feedback: - Palette: drop the cream/Anthropic-feel paper (#F4F1E8) for a DeepSeek-aligned cool white + soft gray (#FFFFFF / #F4F6FB), with indigo accents kept. Soften default hairlines so a pure-white background reads clean instead of harsh. - Mobile: add a hamburger menu (mobile-menu.tsx) so phones can reach Install / Docs / Activity / Roadmap / Contribute — previously the link list was hidden on phones with no replacement. Tighter hero, flexible button row, viewport-safe code blocks, columnar grids collapse cleanly under 768px, and the printed-almanac center rule is desktop-only now (it sliced through narrow viewports). - "How it works" diagram: replace the hand-rolled ASCII art (which misaligned under CJK monospace because Han characters take 2 columns vs Latin's 1, per dhh's note in WeChat) with a real mermaid diagram rendered client-side via dynamic import. Uses the mermaid.live standard syntax 庄表伟 recommended. - Issue #1104: the docs listed a `deepseek-cn` provider that the v0.8.16 binary doesn't accept (`ProviderArg` in crates/cli only has 9 variants; the 10th lives only in the legacy tui/config.rs). derive-facts.mjs now omits `deepseek-cn` until that variant is wired through the shared ProviderKind, and the install page's China-network recipe uses `base_url` / `DEEPSEEK_BASE_URL` (which actually works on v0.8.16) instead of the unsupported provider. Auto-deploys via .github/workflows/deploy-web.yml on push to main. Co-authored-by: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
57 lines
1.6 KiB
TypeScript
57 lines
1.6 KiB
TypeScript
import type { Metadata } from "next";
|
|
import { Fraunces, IBM_Plex_Sans, JetBrains_Mono, Noto_Serif_SC } from "next/font/google";
|
|
import "./globals.css";
|
|
|
|
const display = Fraunces({
|
|
subsets: ["latin"],
|
|
weight: ["400", "500", "600", "700"],
|
|
variable: "--font-display",
|
|
display: "swap",
|
|
});
|
|
|
|
const body = IBM_Plex_Sans({
|
|
subsets: ["latin"],
|
|
weight: ["400", "500", "600"],
|
|
variable: "--font-body",
|
|
display: "swap",
|
|
});
|
|
|
|
const mono = JetBrains_Mono({
|
|
subsets: ["latin"],
|
|
weight: ["400", "500", "600"],
|
|
variable: "--font-mono",
|
|
display: "swap",
|
|
});
|
|
|
|
// Noto Serif SC is heavy; load only what we need for decorative anchors.
|
|
const cjk = Noto_Serif_SC({
|
|
subsets: ["latin"],
|
|
weight: ["400", "700"],
|
|
variable: "--font-cjk",
|
|
display: "swap",
|
|
preload: false,
|
|
});
|
|
|
|
export const metadata: Metadata = {
|
|
title: "DeepSeek TUI · 深度求索 终端",
|
|
description:
|
|
"Terminal-native coding agent built on DeepSeek V4. Open source. Community site for installation, docs, roadmap, and live activity from the Hmbown/deepseek-tui repo.",
|
|
metadataBase: new URL("https://deepseek-tui.com"),
|
|
openGraph: {
|
|
title: "DeepSeek TUI",
|
|
description: "Terminal-native coding agent built on DeepSeek V4.",
|
|
url: "https://deepseek-tui.com",
|
|
siteName: "DeepSeek TUI",
|
|
type: "website",
|
|
},
|
|
twitter: { card: "summary_large_image" },
|
|
};
|
|
|
|
export default function RootLayout({ children }: { children: React.ReactNode }) {
|
|
return (
|
|
<html lang="en" className={`${display.variable} ${body.variable} ${mono.variable} ${cjk.variable}`}>
|
|
<body>{children}</body>
|
|
</html>
|
|
);
|
|
}
|