# Superport ERP System > πŸ’‘ **Note**: Global Claude Code rules are in `~/.claude/CLAUDE.md`. This document contains project-specific context. ## 🎯 Project Overview **Superport**λŠ” κΈ°μ—…μš© μž₯λΉ„ 관리 및 μœ μ§€λ³΄μˆ˜λ₯Ό μœ„ν•œ ν΄λΌμš°λ“œ 기반 ERP μ‹œμŠ€ν…œμž…λ‹ˆλ‹€. ### Business Purpose - μž₯λΉ„ μž…μΆœκ³  및 재고 관리 μžλ™ν™” - μœ μ§€λ³΄μˆ˜ λΌμ΄μ„ μŠ€ 만료일 좔적 - 고객사별 μž₯λΉ„ 배치 ν˜„ν™© 관리 - μ‹€μ‹œκ°„ λŒ€μ‹œλ³΄λ“œλ₯Ό ν†΅ν•œ 경영 μΈμ‚¬μ΄νŠΈ 제곡 ### Target Users - **κ΄€λ¦¬μž (Admin)**: 전체 μ‹œμŠ€ν…œ 관리, μ‚¬μš©μž κΆŒν•œ μ„€μ • - **λ§€λ‹ˆμ € (Manager)**: μž₯λΉ„ μž…μΆœκ³  승인, λΌμ΄μ„ μŠ€ 관리 - **일반 μ‚¬μš©μž (Member)**: μž₯λΉ„ 쑰회, κΈ°λ³Έ μž‘μ—… μˆ˜ν–‰ ## πŸ—οΈ Technical Architecture ### Tech Stack ```yaml Frontend: platform: Flutter Web (Mobile ready) state_management: Provider + ChangeNotifier ui_framework: ShadCN Flutter Port api_client: Dio + Retrofit code_generation: Freezed + JsonSerializable Backend: language: Rust framework: Actix-Web database: PostgreSQL auth: JWT (24μ‹œκ°„ 만료) api_url: http://43.201.34.104:8080/api/v1 source_path: /Users/maximilian.j.sul/Documents/flutter/superport_api Infrastructure: hosting: AWS (μ˜ˆμ •) storage: S3 (μ˜ˆμ •) ci_cd: GitHub Actions (μ˜ˆμ •) ``` ### Project Structure ``` /Users/maximilian.j.sul/Documents/flutter/ β”œβ”€β”€ superport/ # Flutter Frontend β”‚ β”œβ”€β”€ lib/ β”‚ β”‚ β”œβ”€β”€ core/ # 핡심 μ„€μ • 및 μœ ν‹Έλ¦¬ν‹° β”‚ β”‚ β”œβ”€β”€ data/ # API 톡신 λ ˆμ΄μ–΄ β”‚ β”‚ β”‚ β”œβ”€β”€ models/ # Freezed DTO β”‚ β”‚ β”‚ └── datasources/ # API ν΄λΌμ΄μ–ΈνŠΈ β”‚ β”‚ β”œβ”€β”€ screens/ # UI ν™”λ©΄ β”‚ β”‚ β”‚ └── [feature]/ β”‚ β”‚ β”‚ β”œβ”€β”€ controllers/ # μƒνƒœ 관리 β”‚ β”‚ β”‚ └── widgets/ # UI μ»΄ν¬λ„ŒνŠΈ β”‚ β”‚ └── services/ # λΉ„μ¦ˆλ‹ˆμŠ€ 둜직 β”‚ └── superport_api/ # Rust Backend β”œβ”€β”€ src/ β”‚ β”œβ”€β”€ handlers/ # API μ—”λ“œν¬μΈνŠΈ β”‚ β”œβ”€β”€ services/ # λΉ„μ¦ˆλ‹ˆμŠ€ 둜직 β”‚ └── entities/ # DB λͺ¨λΈ └── migrations/ # DB λ§ˆμ΄κ·Έλ ˆμ΄μ…˜ ``` ## βœ… Implementation Status ### Completed Features (100%) - βœ… **인증 μ‹œμŠ€ν…œ**: JWT 기반 둜그인/λ‘œκ·Έμ•„μ›ƒ - βœ… **νšŒμ‚¬ 관리**: CRUD, 지점 관리, μ—°λ½μ²˜ 정보 - βœ… **μ‚¬μš©μž 관리**: 계정 생성, κΆŒν•œ μ„€μ • (Admin/Manager/Member) - βœ… **μ°½κ³  μœ„μΉ˜ 관리**: μž…κ³ μ§€ 등둝 및 관리 - βœ… **μž₯λΉ„ μž…κ³ **: μ‹œλ¦¬μ–Ό 번호 좔적, μˆ˜λŸ‰ 관리 - βœ… **λΌμ΄μ„ μŠ€ 관리**: μœ μ§€λ³΄μˆ˜ κΈ°κ°„, 만료일 μ•Œλ¦Ό ### In Progress (70%) - πŸ”„ **μž₯λΉ„ 좜고**: API 연동 μ™„λ£Œ, UI κ°œμ„  ν•„μš” - πŸ”„ **λŒ€μ‹œλ³΄λ“œ**: κΈ°λ³Έ 톡계 ν‘œμ‹œ, 차트 κ΅¬ν˜„ 쀑 - πŸ”„ **검색 및 ν•„ν„°**: κΈ°λ³Έ 검색 κ΅¬ν˜„, κ³ κΈ‰ ν•„ν„° 개발 쀑 ### Not Started (0%) - ⏳ **μž₯λΉ„ λŒ€μ—¬**: λŒ€μ—¬/λ°˜λ‚© ν”„λ‘œμ„ΈμŠ€ - ⏳ **μž₯λΉ„ 폐기**: 폐기 μ‚¬μœ  및 이λ ₯ 관리 - ⏳ **λ³΄κ³ μ„œ 생성**: Excel/PDF 내보내기 - ⏳ **λͺ¨λ°”일 μ•±**: λ°˜μ‘ν˜• λ ˆμ΄μ•„μ›ƒ μ΅œμ ν™” - ⏳ **μ•Œλ¦Ό μ‹œμŠ€ν…œ**: 이메일/ν‘Έμ‹œ μ•Œλ¦Ό ## πŸ› Known Issues ### Critical ```yaml μ‹œλ¦¬μ–Ό_번호_쀑볡: location: "μž₯λΉ„ μž…κ³  ν”„λ‘œμ„ΈμŠ€" issue: "λ°±μ—”λ“œμ—μ„œ 쀑볡 체크 λ―Έκ΅¬ν˜„" workaround: "ν”„λ‘ νŠΈμ—”λ“œ μž„μ‹œ 검증" priority: HIGH κΆŒν•œ_체크_λˆ„λ½: location: ["warehouse_location", "overview"] issue: "일뢀 ν™”λ©΄μ—μ„œ μ—­ν•  기반 μ ‘κ·Ό μ œμ–΄ 미적용" impact: "λͺ¨λ“  μ‚¬μš©μžκ°€ μ ‘κ·Ό κ°€λŠ₯" priority: HIGH ``` ### Minor ```yaml μƒνƒœ_κ°±μ‹ _μ§€μ—°: location: "CRUD μž‘μ—… ν›„ 리슀트 ν™”λ©΄" issue: "일뢀 ν™”λ©΄μ—μ„œ μžλ™ μƒˆλ‘œκ³ μΉ¨ λ―Έμž‘λ™" workaround: "μˆ˜λ™ μƒˆλ‘œκ³ μΉ¨" priority: MEDIUM λ‚ μ§œ_포맷: location: "λΌμ΄μ„ μŠ€ 만료일" issue: "ν•œκ΅­ μ‹œκ°„λŒ€ ν‘œμ‹œ 뢈일치" priority: LOW ``` ## πŸ“‹ TODO List ### Immediate (This Week) - [ ] μž₯λΉ„ 좜고 ν”„λ‘œμ„ΈμŠ€ μ™„μ„± - [ ] λŒ€μ‹œλ³΄λ“œ 차트 κ΅¬ν˜„ (Chart.js 톡합) - [ ] μ‹œλ¦¬μ–Ό 번호 쀑볡 체크 λ°±μ—”λ“œ κ΅¬ν˜„ - [ ] κΆŒν•œ 체크 λˆ„λ½ ν™”λ©΄ μˆ˜μ • ### Short Term (This Month) - [ ] μž₯λΉ„ λŒ€μ—¬/λ°˜λ‚© κΈ°λŠ₯ κ΅¬ν˜„ - [ ] κ³ κΈ‰ 검색 ν•„ν„° κ΅¬ν˜„ - [ ] Excel 내보내기 κΈ°λŠ₯ - [ ] μ„±λŠ₯ μ΅œμ ν™” (가상 슀크둀링) ### Long Term - [ ] λͺ¨λ°”일 μ•± μ΅œμ ν™” - [ ] ν‘Έμ‹œ μ•Œλ¦Ό μ‹œμŠ€ν…œ - [ ] λ‹€κ΅­μ–΄ 지원 (μ˜μ–΄) - [ ] λŒ€μ‹œλ³΄λ“œ μ»€μŠ€ν„°λ§ˆμ΄μ§• ## πŸ”‘ Key Decisions ### 2025-01-07 - **Decision**: Mock μ„œλΉ„μŠ€ 제거, Real API μ „μš©μœΌλ‘œ μ „ν™˜ - **Reason**: 개발 ν™˜κ²½ λ‹¨μˆœν™” 및 μ‹€μ œ ν™˜κ²½ ν…ŒμŠ€νŠΈ κ°•ν™” ### 2025-01-06 - **Decision**: Provider νŒ¨ν„΄ μœ μ§€ (Riverpod λ§ˆμ΄κ·Έλ ˆμ΄μ…˜ 보λ₯˜) - **Reason**: ν˜„μž¬ ꡬ쑰가 μ•ˆμ •μ , νŒ€ ν•™μŠ΅ 곑선 κ³ λ € ### 2024-12-20 - **Decision**: Flutter Web μš°μ„  개발 - **Reason**: λΉ λ₯Έ 배포와 크둜슀 ν”Œλž«νΌ 지원 ## πŸš€ Quick Commands ### Development ```bash # Start development (Real API) flutter run -d chrome # Run tests flutter test # Generate code (Freezed, JsonSerializable) flutter pub run build_runner build --delete-conflicting-outputs # API integration test ./test_api_integration.sh # Start backend API (별도 터미널) cd /Users/maximilian.j.sul/Documents/flutter/superport_api cargo run # View API logs cd /Users/maximilian.j.sul/Documents/flutter/superport_api tail -f logs/api.log ``` ### API Configuration ``` Base URL: http://43.201.34.104:8080/api/v1 Test Account: admin@superport.kr / admin123! API Source Code: /Users/maximilian.j.sul/Documents/flutter/superport_api ``` ## πŸ“ž Team Contacts - **Backend API Issues**: Rust λ°±μ—”λ“œ νŒ€ - **UI/UX Questions**: λ””μžμΈ νŒ€ - **Business Logic**: ν”„λ‘œλ•νŠΈ λ§€λ‹ˆμ € --- **Project Stage**: Development (70% Complete) **Next Milestone**: Beta Release (2025-02-01) **Last Updated**: 2025-01-08 **Version**: 3.0