mirror of
https://github.com/karpathy/nanochat.git
synced 2026-05-09 01:10:10 +00:00
Build services/frontend/ replacing the legacy nanochat/ui.html single-file UI. Landing, login, and chat pages ported with full design system: Devanagari + Great Vibes hero, samosa/chai/toran SVG animations, gold/cream palette. - App Router pages: / (hero + floating illustrations), /login (split-screen OAuth with mandala motif), /chat (260px collapsible sidebar, suggestion chips, markdown + code-copy, auto-expanding input, slash commands) - SSE streaming via useSSE hook and /api/chat/stream BFF route (proxies to CHAT_API_URL when set, falls back to mock echo for local dev) - NextAuth.js v5 with Google + GitHub providers; middleware gates /chat/* - Zustand store with localStorage persistence for conversations/settings - Tailwind theme carries all ui.html tokens + keyframes (pendulum, float, wobble, steamFloat, steamType); SVG assets componentized under components/svg - Multi-stage node:20-alpine Dockerfile with Next standalone output Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
20 lines
512 B
TypeScript
20 lines
512 B
TypeScript
import { auth } from '@/auth';
|
|
import { NextResponse } from 'next/server';
|
|
|
|
export default auth((req) => {
|
|
const { nextUrl } = req;
|
|
const isAuthed = !!req.auth;
|
|
const isChatRoute = nextUrl.pathname.startsWith('/chat');
|
|
|
|
if (isChatRoute && !isAuthed) {
|
|
const loginUrl = new URL('/login', nextUrl);
|
|
loginUrl.searchParams.set('callbackUrl', nextUrl.pathname);
|
|
return NextResponse.redirect(loginUrl);
|
|
}
|
|
return NextResponse.next();
|
|
});
|
|
|
|
export const config = {
|
|
matcher: ['/chat/:path*'],
|
|
};
|