diff --git a/CLAUDE.md b/CLAUDE.md new file mode 100644 index 0000000..14defa0 --- /dev/null +++ b/CLAUDE.md @@ -0,0 +1,126 @@ +# CLAUDE.md + +This file provides guidance to Claude Code (claude.ai/code) when working with code in this repository. + +## Project Overview + +**QuantEngine v0.1** — A comprehensive quantitative analysis and data collection system for retirement asset portfolio management. + +- **Architecture**: .NET 9 + C# (web UI + APIs), Python (legacy data collection/analysis) +- **Web UI**: Blazor WebAssembly (Fluent UI Blazor v5) + ASP.NET Core Web API +- **Database**: PostgreSQL (Npgsql 8.0), single unified database +- **Data Source**: KIS Open API (quotations/ranking read-only), with fallbacks +- **Key Runtimes**: .NET 9, Python 3.9+, Node.js 16+ + +### Current Status (2026-06-29) + +- ✅ Python codebase operational (1,140 files) +- ✅ .NET 9 migration in progress (Phase 1: Web UI) +- ✅ Blazor WASM with Fluent UI v5 RC baseline +- ✅ ASP.NET Core API endpoints operational +- ✅ PostgreSQL migration complete + +## Deployment & Operations + +**Production Server**: Hetzner Cloud `178.104.200.7` (kjh2064@178.104.200.7) + +Projects on server: +1. **TaxBaik** (홈페이지) — Nginx location `/taxbaik` +2. **QuantEngine** (데이터 수집/분석) — Nginx location `/quantengine` + +See [Temp/DEPLOYMENT_GUIDE.md](Temp/DEPLOYMENT_GUIDE.md) for deployment procedures. + +### Quick Deploy (QuantEngine) + +```powershell +ssh kjh2064@178.104.200.7 +systemctl status quantengine-api +journalctl -u quantengine-api -f +sudo systemctl restart quantengine-api +``` + +### Git Repository + +**Gitea Server** (동일 호스트): +- **HTTP**: `http://178.104.200.7/kjh2064/QuantEngineByItz.git` +- **SSH**: `git@178.104.200.7:2222/...` + +## UI Design Principles (2026-06-29) + +### Framework & Design System + +- **Primary Framework**: [Fluent UI Blazor v5](https://v5.fluentui-blazor.net/) +- **Design System**: Microsoft Fluent Design System (WCAG 2.1 AA) +- **Deprecation**: MudBlazor is deprecated. Migrate all existing pages to Fluent UI v5 progressively. + +### Component Development Rules + +1. **All UI Development** (New + Refactored): + - Use Fluent UI Blazor v5 components exclusively + - Fall back to pure HTML/CSS if Fluent v5 doesn't provide + - **Never introduce MudBlazor components** (deprecated) + - Progressively migrate existing MudBlazor to Fluent v5 + +2. **Loading States** (Priority order): + - `` — **Default** for lists, cards, dashboards, detail pages + - Pure HTML `
` — For custom layouts + - `MudProgressCircular` / `MudProgressLinear` — Exception only (existing legacy) + - Blocking spinners — **Avoid** + +3. **Data Rendering Pattern**: + - First render: Skeleton placeholders only + - On data arrival: Replace skeleton with actual UI + - Never show blank states while loading + +4. **Component Mapping** (Fluent UI v5): + +| UI Element | Fluent UI Component | Alternative | +|-----------|-------------------|-------------| +| Button | `` | - | +| Input field | `` | HTML `` | +| Dropdown | `` | HTML `