--- source: Phase 0 분석 기반 아키텍처 옵션 분석 section: 백엔드-프론트엔드 협업 논의 자료 (핵심 버전) created: 2025-11-13 audience: 백엔드 개발자 + 프론트엔드 개발자 purpose: 아키텍처 방향 결정을 위한 논의 자료 tags: [architecture, options, collaboration, discussion] --- # 품목 관리 시스템 아키텍처 옵션 분석 **목적:** 현재 품목 관리 화면의 구조적 문제를 해결하기 위한 아키텍처 접근 방식 비교 **대상:** 백엔드 개발자 + 프론트엔드 개발자 협업 논의용 **범위:** 개념적 분석 (구현 상세 제외) --- ## 📊 현재 구조 분석 ### 1. 품목 유형 및 필드 구성 **5가지 주요 품목 유형:** ``` 품목 유형 계층: ├─ FG (제품) │ └─ 필드: 상품명, 품목명, 규격, ... │ ├─ PT (부품) ─┬─ ASSEMBLY (조립) ─── 12개 카테고리 │ │ ├─ guide_rail: 설치유형, 조립유형, 사이드규격, 조립길이 │ │ ├─ case: 조립유형 │ │ ├─ bottom_finish: 재질, 형상 │ │ ├─ rod: 직경, 길이 │ │ ├─ frame: 위치, 길이 │ │ ├─ bracket: 설치유형, 규격 │ │ ├─ cover: 재질, 길이 │ │ ├─ cap: 위치, 직경 │ │ ├─ endcap: 위치, 직경 │ │ ├─ stopper: 동작유형, 용량 │ │ ├─ safety: 안전장치유형, 용량 │ │ └─ motor: 모터타입, 출력 │ │ │ ├─ BENDING (절곡) │ │ └─ 필드: 재질, 두께, 절곡도면, 절곡상세 │ │ │ └─ PURCHASED (구매) │ └─ 필드: 카테고리, 구매처, 규격 │ ├─ RM (원자재) │ └─ 필드: 재질, 규격, 단위, 구매단가 │ ├─ SM (부자재) │ └─ 필드: 재질, 규격, 단위, 구매단가 │ └─ CS (소모품) └─ 필드: 재질, 규격, 단위, 구매단가 ``` **핵심 특징:** - 품목 유형에 따라 **완전히 다른 필드 세트** 필요 - PT-ASSEMBLY는 12개 카테고리별로 **고유한 필드 조합** - 총 추정 **40-50개 이상의 필드**가 조건부로 표시됨 --- ### 2. 현재 구현 방식 **6,521줄 단일 파일 (ItemManagement.tsx)** ``` 구조: ├─ 40개 useState (모든 필드를 상태로 관리) ├─ 177줄 코드 생성 로직 (12개 if-else 분기) ├─ 100줄 검증 로직 (품목 유형별 검증 규칙) ├─ 1,911줄 리스트 뷰 (7개 탭 × 테이블 구조 반복) └─ 1,780줄 폼 (품목 유형별 조건부 렌더링) ``` **동작 방식:** ``` 사용자가 품목 유형 선택 ↓ if (itemType === "FG") { → FG 전용 필드 표시 } else if (itemType === "PT" && partType === "ASSEMBLY") { if (category1 === "guide_rail") { → 가이드레일 전용 필드 표시 } else if (category1 === "case") { → 케이스 전용 필드 표시 } // ... 12개 카테고리 반복 } // ... 5개 품목 유형 반복 ``` **문제점:** - ❌ **유지보수 불가능:** 새로운 카테고리 추가 시 여러 곳 수정 필요 - ❌ **코드 중복:** 테이블 구조 10회, 검증 로직 분산 - ❌ **확장성 제한:** 필드 추가/수정 시 소스 코드 직접 변경 필요 - ❌ **성능 저하:** 40개 useState, 거대한 단일 컴포넌트 --- ## 🎯 아키텍처 옵션 비교 ### Option A: 고정 화면 유지 (현재 방식 개선) **개념:** - 현재 구조 유지, 리팩토링으로 품질 개선 - 품목 유형별로 화면을 작은 컴포넌트로 분리 - 여전히 화면은 "고정"되어 있음 ``` 구조 변경: ItemManagement.tsx (6,521줄) ↓ 분리 ├─ ItemListView.tsx (200줄) ← DataTable 재사용 ├─ ItemFormDialog.tsx (300줄) │ ├─ FGForm.tsx (150줄) │ ├─ PTAssemblyForm.tsx (200줄) │ │ ├─ GuideRailFields.tsx │ │ ├─ CaseFields.tsx │ │ └─ ... (12개 컴포넌트) │ ├─ PTBendingForm.tsx (100줄) │ └─ PTPurchasedForm.tsx (100줄) └─ hooks/ ├─ useItemForm.ts (상태 관리) └─ useItemValidation.ts (검증 로직) ``` **장점:** - ✅ 단순하고 직관적 - ✅ 개발 속도 빠름 (리팩토링만) - ✅ 프론트엔드 자체 완결 (백엔드 의존 최소) - ✅ 타입 안전성 높음 (TypeScript 완전 지원) **단점:** - ❌ 새 품목 유형/카테고리 추가 시 소스 수정 필요 - ❌ 필드 변경 시 프론트엔드 배포 필요 - ❌ 여러 시스템에서 사용 시 중복 개발 **백엔드 요구사항:** - 단순 CRUD API (GET/POST/PUT/DELETE /api/items) - 품목 유형별 필드는 모두 고정 컬럼 **프론트엔드 요구사항:** - 컴포넌트 분리 작업 (4-7주) - 품목 유형별 폼 컴포넌트 개발 (12개) --- ### Option B: 메타데이터 기반 동적 UI **개념:** - 화면 구성 정보를 데이터베이스에 저장 - 프론트엔드는 메타데이터를 읽어 동적으로 화면 구성 - 관리자 화면에서 필드 추가/수정 가능 ``` 동작 방식: DB: item_field_metadata 테이블 ┌────────────┬─────────────┬──────────────┬───────────────┐ │ item_type │ field_name │ field_type │ field_config │ ├────────────┼─────────────┼──────────────┼───────────────┤ │ FG │ productName │ text │ {required} │ │ FG │ itemName │ text │ {required} │ │ PT-guide │ installType │ select │ {wall,stand} │ │ PT-guide │ assemblyType│ select │ {M,T,P,B,S} │ └────────────┴─────────────┴──────────────┴───────────────┘ ↓ 프론트엔드가 읽음 ↓ ↓ 화면 자동 생성 ``` **예시: 새 필드 추가** ``` 관리자: "guide_rail에 '표면처리' 필드 추가" ↓ DB에 메타데이터 INSERT ↓ 화면 자동 반영 (소스 수정 없음) ``` **장점:** - ✅ 확장성 최고: 필드 추가/수정 시 소스 변경 불필요 - ✅ 유연성: 품목 유형 추가 쉬움 - ✅ 중앙 관리: 메타데이터 한 곳에서 관리 - ✅ 재사용성: 다른 시스템에도 적용 가능 **단점:** - ❌ 복잡도 높음: 메타데이터 시스템 개발 필요 - ❌ 개발 시간 김: 초기 구축 오래 걸림 (8-12주) - ❌ 디버깅 어려움: 동적 생성으로 에러 추적 어려움 - ❌ 타입 안전성 낮음: 런타임 에러 가능성 **백엔드 요구사항:** - 메타데이터 관리 시스템 (CRUD) - GET /api/items/metadata?itemType=FG - 메타데이터 변경 이력 관리 - 메타데이터 기반 검증 로직 **프론트엔드 요구사항:** - 메타데이터 기반 폼 렌더링 엔진 - 동적 검증 시스템 - 메타데이터 관리 화면 --- ### Option C: 하이브리드 (고정 + 동적) **개념:** - 핵심 필드는 고정 (고정 화면) - 확장 필드는 동적 (메타데이터) - 게시판 시스템의 `board_settings` 패턴 차용 ``` 필드 구분: 고정 필드 (Fixed Fields): - itemType, itemName, specification, category - → 테이블 컬럼, TypeScript 타입 정의 - → 고정 UI 컴포넌트 확장 필드 (Dynamic Fields): - 품목 유형별 추가 속성 - → JSON 컬럼 (attributes) 저장 - → 메타데이터 기반 동적 렌더링 예시: products 테이블 ├─ 고정: id, item_type, item_name, specification (컬럼) └─ 동적: attributes (JSON) ← {installationType: 'wall', assemblyType: 'M'} ``` **게시판 패턴 참고:** ``` 현재 SAM 게시판 시스템: ├─ boards (게시판 기본 설정) ├─ board_settings (동적 필드 정의) └─ post_custom_field_values (동적 필드 값) ↓ 품목 시스템 적용: ├─ item_types (품목 기본 설정) ├─ item_field_settings (동적 필드 정의) └─ product_attributes (동적 필드 값) ``` **장점:** - ✅ 균형: 단순함 + 확장성 조화 - ✅ 점진 확장: 필요시 동적 필드 추가 - ✅ 성능: 핵심 필드는 빠름 (인덱싱 가능) - ✅ 타입 안전성: 핵심 필드는 타입 보장 **단점:** - ⚠️ 복잡도 중간: 두 시스템 혼재 - ⚠️ 경계 모호: 어디까지 고정? 어디부터 동적? - ⚠️ 학습 곡선: 두 방식 모두 이해 필요 **백엔드 요구사항:** - 고정 필드: 일반 CRUD - 동적 필드: 메타데이터 시스템 (간소화 버전) - Hybrid 검증 로직 **프론트엔드 요구사항:** - 고정 폼 컴포넌트 - 동적 필드 렌더러 - Hybrid 상태 관리 --- ## ⚖️ Trade-off 분석 ### 1. 개발 시간 | 옵션 | 백엔드 | 프론트엔드 | 총계 | 비고 | |------|--------|-----------|------|------| | A. 고정 화면 | 1-2주 | 4-7주 | **5-9주** | 리팩토링 작업 | | B. 메타데이터 | 4-6주 | 4-6주 | **8-12주** | 시스템 구축 | | C. 하이브리드 | 2-4주 | 4-7주 | **6-11주** | 점진적 확장 | --- ### 2. 유지보수성 | 시나리오 | Option A | Option B | Option C | |----------|----------|----------|----------| | 새 품목 유형 추가 | ❌ 소스 수정 필요 (1-2일) | ✅ 메타데이터만 추가 (1시간) | ⚠️ 고정 필드 추가 + 메타 (반나절) | | 기존 필드 수정 | ❌ 소스 + 배포 (반나절) | ✅ 메타데이터 수정 (즉시) | ⚠️ 고정 필드는 배포 필요 | | 검증 규칙 변경 | ❌ 소스 수정 필요 | ✅ 메타데이터 규칙 변경 | ⚠️ 고정은 소스, 동적은 메타 | --- ### 3. 성능 | 관점 | Option A | Option B | Option C | |------|----------|----------|----------| | 초기 로딩 | ✅ 빠름 (정적) | ⚠️ 느림 (메타 로딩) | ⚠️ 중간 | | 검색/필터 | ✅ 빠름 (인덱싱) | ❌ 느림 (JSON 검색) | ⚠️ 고정 필드만 빠름 | | 렌더링 | ✅ 최적화 쉬움 | ❌ 동적 생성 오버헤드 | ⚠️ Hybrid | --- ### 4. 확장성 | 요구사항 | Option A | Option B | Option C | |----------|----------|----------|----------| | 새 화면 추가 | ❌ 컴포넌트 개발 필요 | ✅ 메타데이터로 자동 | ⚠️ 부분 자동화 | | 다른 시스템 적용 | ❌ 재개발 필요 | ✅ 메타데이터 복사 | ⚠️ 고정 부분 재개발 | | 비즈니스 변화 대응 | ❌ 개발팀 의존 | ✅ 관리자가 직접 설정 | ⚠️ 간단한 건 관리자, 복잡한 건 개발 | --- ### 5. 복잡도 | 관점 | Option A | Option B | Option C | |------|----------|----------|----------| | 시스템 복잡도 | ✅ 단순 | ❌ 복잡 | ⚠️ 중간 | | 디버깅 | ✅ 쉬움 | ❌ 어려움 (동적) | ⚠️ 중간 | | 타입 안전성 | ✅ 높음 | ❌ 낮음 | ⚠️ 고정만 높음 | --- ## 🤔 논의 포인트 ### 1. 비즈니스 요구사항 **질문:** - [ ] 품목 유형/카테고리가 얼마나 자주 추가/변경되는가? - 거의 없음 → Option A 유리 - 자주 변경 → Option B/C 유리 - [ ] 관리자가 직접 필드를 추가/수정할 필요가 있는가? - 필요 없음 → Option A - 필요함 → Option B/C - [ ] 이 시스템을 다른 곳에도 적용할 계획인가? - 없음 → Option A - 있음 → Option B/C --- ### 2. 기술적 제약 **질문:** - [ ] 개발 일정이 얼마나 타이트한가? - 빠른 출시 필요 → Option A - 장기 프로젝트 → Option B/C - [ ] 팀의 기술 수준은? - 메타데이터 시스템 경험 없음 → Option A/C - 복잡한 시스템 경험 있음 → Option B - [ ] 성능 요구사항은? - 매우 중요 → Option A - 유연성이 더 중요 → Option B/C --- ### 3. 백엔드-프론트엔드 역할 분담 | 작업 | Option A | Option B | Option C | |------|----------|----------|----------| | 새 필드 추가 시 | 백+프 둘 다 작업 | 백엔드만 (메타데이터) | 백+프 (필드 유형에 따라) | | 검증 로직 | 프론트 중심 | 백엔드 중심 | 협의 필요 | | UI 렌더링 | 프론트 완전 제어 | 메타데이터 제약 | Hybrid | --- ### 4. 점진적 확장 가능성 **질문:** - [ ] Option A로 시작해서 나중에 Option B/C로 전환 가능한가? - 가능하지만 전면 재작업 필요 - [ ] Option C를 선택하면 어디까지를 "고정"으로 할 것인가? - 제안: 핵심 필드 (itemType, itemName, specification, category) 고정 - 제안: 품목 유형별 특수 속성은 동적 --- ## 💡 권장 방향 (토의용) ### 상황별 권장 옵션 **다음 경우 Option A 권장:** - ✓ 품목 유형이 거의 고정되어 있음 - ✓ 빠른 출시가 중요 - ✓ 시스템이 단일 프로젝트에만 사용됨 - ✓ 프론트엔드 팀이 리팩토링 경험 풍부 **다음 경우 Option B 권장:** - ✓ 품목 유형이 자주 변경됨 - ✓ 관리자가 직접 설정 변경 필요 - ✓ 여러 시스템에 적용 계획 - ✓ 장기 프로젝트 (충분한 개발 기간) **다음 경우 Option C 권장:** - ✓ Option A와 B 사이에서 고민 - ✓ 현재는 고정, 미래에 확장 가능성 - ✓ 성능과 유연성 둘 다 중요 - ✓ 게시판 패턴 경험 있음 --- ## 📌 다음 단계 1. **이 문서를 바탕으로 팀 내 토의** - 비즈니스 요구사항 명확화 - 기술적 제약 확인 - 우선순위 결정 2. **옵션 선택 후:** - 백엔드: DB 스키마 설계 - 프론트엔드: 컴포넌트 구조 설계 - 함께: API 계약 정의 3. **프로토타입 개발 고려:** - 선택한 옵션으로 1-2개 품목 유형 먼저 구현 - 실제 사용성 검증 후 전체 확장 --- ## 📚 참고 자료 - **Phase 0 분석 보고서:** `claudedocs/mes/00_baseline/PHASE_0_FINAL_REPORT.md` - **현재 코드 분석:** `claudedocs/mes/00_baseline/docs_breakdown/react_code_analysis_summary.md` - **API 분석:** `claudedocs/mes/00_baseline/docs_breakdown/api_code_analysis_summary.md` - **Gap 검증:** `claudedocs/mes/00_baseline/docs_breakdown/api_gap_validation_report.md` --- **작성일:** 2025-11-13 **버전:** 1.0 (핵심 버전) **다음:** 상세 버전 (`ARCHITECTURE_OPTIONS_DETAILED.md`)