# 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 `