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>
38 lines
1.1 KiB
TypeScript
38 lines
1.1 KiB
TypeScript
import handler from "./.open-next/worker.js";
|
|
import {
|
|
runCurate,
|
|
runTriage,
|
|
runPrReview,
|
|
runStale,
|
|
runDupes,
|
|
runDigest,
|
|
type AgentEnv,
|
|
} from "./lib/community-agent-tasks";
|
|
import { runFactsDrift } from "./lib/facts-drift";
|
|
import { runLinkCheck, runSemanticDrift } from "./lib/content-watch";
|
|
|
|
export default {
|
|
fetch: handler.fetch,
|
|
async scheduled(event: ScheduledEvent, env: Record<string, unknown>, ctx: ExecutionContext) {
|
|
const expr = event.cron;
|
|
ctx.waitUntil((async () => {
|
|
const agentEnv = env as unknown as AgentEnv;
|
|
if (expr === "0 */6 * * *") {
|
|
await runCurate(agentEnv);
|
|
await runFactsDrift(agentEnv);
|
|
}
|
|
else if (expr === "*/30 * * * *") {
|
|
await runTriage(agentEnv);
|
|
await runPrReview(agentEnv);
|
|
}
|
|
else if (expr === "0 0 * * *") {
|
|
await runStale(agentEnv);
|
|
await runDupes(agentEnv);
|
|
await runLinkCheck(agentEnv);
|
|
await runSemanticDrift(agentEnv);
|
|
}
|
|
else if (expr === "0 9 * * 1") await runDigest(agentEnv);
|
|
})());
|
|
},
|
|
} satisfies ExportedHandler;
|