- 2025-12-28 고객센터 시스템 게시판 API 연동 수정 기록 - 날짜 범위 필터 초기값 변경 내용 문서화 fix: 고객센터 목록 날짜 범위 초기값 변경 - EventList, InquiryList, NoticeList 날짜 범위 초기값 빈 문자열로 변경 - 페이지 진입 시 전체 데이터 조회 가능하도록 수정 feat: 1:1 문의 댓글 기능 API 연동 - 댓글 CRUD API 함수 구현 (shared/actions.ts) - getComments, createComment, updateComment, deleteComment - CommentApiData 타입 및 transformApiToComment 변환 함수 추가 - InquiryDetail 컴포넌트 callback props 방식으로 변경 - user.id localStorage 저장으로 본인 글 수정/삭제 버튼 표시 - page.tsx에서 댓글 API 호출 및 상태 관리 feat(WEB): 게시판 시스템 Mock → API 연동 (Phase J) - BoardList: getPosts, getMyPosts API 연동 - BoardDetail: getPost API 연동, 새 라우트 구조 적용 - BoardForm: getBoards, createPost, updatePost API 연동 - 라우트 변경: /board/[id] → /board/[boardCode]/[postId] - Toast 라이브러리 sonner로 통일 - MOCK_BOARDS 완전 제거, types.ts 정리 chore: 작업 현황 업데이트 refactor: BoardForm 부서 Mock 데이터 분리 - types.ts에서 MOCK_DEPARTMENTS 제거 - BoardForm 내부에 임시 Mock 데이터 정의 - TODO: API에서 부서 목록 연동 필요 feat: 종합현황 반려 사유 입력 Dialog 추가 - 반려 시 사유 입력 Dialog 표시 - 사유 미입력 시 toast 에러 메시지 - rejectIssue 함수에 reason 파라미터 추가 feat: 고객센터 Mock → API 연동 완료 - shared/actions.ts: 공통 게시글 API 액션 추가 - shared/types.ts: 공통 타입 정의 - InquiryList: Mock → API 연동, transform 함수 추가 - FAQList: Mock → API 연동, transform 함수 추가 - 상세 페이지: API 연동 (notices, events, inquiries) - 각 types.ts: transformPost 함수 추가 fix: 고객센터 board_code 불일치 수정 - 공지사항: notice → notices - 이벤트: event → events - DB 시스템 게시판 코드와 일치하도록 수정 feat: 결재 문서 작성 파일 첨부 기능 구현 - UploadedFile 타입 추가 및 ProposalData/ExpenseReportData에 uploadedFiles 필드 추가 - uploadFiles() 함수 구현 (/api/v1/files/upload API 연동) - createApproval/updateApproval에서 파일 업로드 후 저장 처리 - ProposalForm/ExpenseReportForm에 첨부파일 UI 개선 - 기존 업로드 파일 표시 (파일 보기/삭제 기능) - 새 첨부 파일 목록 표시 및 삭제 기능 - DraftBox에서 결재자 부서/직책 정보 표시 - 문서 상세 모달에서 실제 API 데이터 표시 (목업 데이터 제거) - 수정 모드 상신 시 PATCH 메서드 사용 (405 에러 수정) feat: [mock-migration] Phase J-4 게시판 관리 Mock → API 연동 완료 - types.ts: BoardApiData, BoardExtraSettings API 타입 추가 - actions.ts: Server Actions 생성 (CRUD, 변환 함수) - index.tsx: Mock 데이터 → API 호출로 전환 - [id]/page.tsx: 상세 페이지 API 연동 - [id]/edit/page.tsx: 수정 페이지 API 연동 - new/page.tsx: 등록 페이지 API 연동 주요 정책: - /boards/tenant 엔드포인트로 테넌트 게시판만 조회 - 수정 시 board_code 전송 안함 (코드 변경 불가) - extra_settings 내 target/target_name 저장 feat: 매입유형(purchase_type) 필드 저장 기능 추가 - actions.ts: API 응답/요청에 purchase_type 매핑 추가 - PurchaseDetail.tsx: 저장 시 purchaseType 포함하도록 수정 fix(salary): 직책/직급 매핑 수정 (사원관리 기준 통일) - transformApiToFrontend: position → job_title_label (직책), rank → rank (직급) - transformApiToDetail: 동일하게 수정 - 기존 잘못된 매핑: position_label(직위) → 직책, job_title_label(직책) → 직급 feat: [mock-migration] Phase M 잔여 Mock/TODO 제거 완료 - M-1: 매입 상세 모달 MOCK_ACCOUNTS, MOCK_VENDORS → API 연동 - M-2: 직원 관리 파일 업로드 API 연동 (uploadProfileImage) - M-4: 결재 문서 생성 MOCK_EMPLOYEES 제거 → getEmployees API - M-5: 결재함/기안함 console.log 제거 → 승인/반려 API 연동 - M-6: 구독 관리 TODO 제거 → requestDataExport, cancelSubscription - M-7: 계정 정보 TODO 제거 → withdrawAccount, suspendTenant docs: 휴가관리 사용현황 동기화 수정 작업 기록 - 2025-12-26 휴가 사용현황 동기화 수정 내용 추가 - fetchUsageData 호출 추가, 부여일수 계산 수정 문서화 feat: Phase G 생산관리/품질검사 Mock → API 연동 완료 G-1 작업지시관리: - WorkOrderList: getWorkOrders, getWorkOrderStats API - WorkOrderDetail: getWorkOrderById API - WorkOrderCreate: createWorkOrder API - SalesOrderSelectModal: getSalesOrdersForWorkOrder API G-2 작업실적관리: - WorkResultList: getWorkResults, getWorkResultStats API G-3 생산대시보드: - actions.ts 생성, getDashboardData API G-4 작업자화면: - actions.ts 생성 - getMyWorkOrders, completeWorkOrder API - MaterialInputModal: getMaterialsForWorkOrder, registerMaterialInput API - ProcessDetailSection: getProcessSteps, requestInspection API G-5 품질검사: - actions.ts 생성 - InspectionList: getInspections, getInspectionStats API - InspectionDetail: getInspectionById, updateInspection API - InspectionCreate: createInspection API fix: [vacation] 휴가 사용현황 동기화 및 부여일수 계산 수정 - 승인 후 fetchUsageData() 호출 추가로 사용현황 즉시 반영 - baseVacation: 동적 totalDays → 고정 '15일' (기본 연차) - grantedVacation: 하드코딩 '0일' → Math.max(0, totalDays-15) 계산 - useCallback dependencies에 fetchUsageData 추가 feat: Phase I Excel/PDF 다운로드 API 연동 - ReceivablesStatus: 채권현황 엑셀 다운로드 API 연동 - VendorLedger: 거래처원장 목록 엑셀, 상세 PDF 다운로드 API 연동 - DailyReport: 일일일보 엑셀 다운로드 API 연동 - Blob 다운로드 패턴 및 toast 알림 적용 feat: L-2 견적 관리 Mock → API 연동 ## 변경사항 - SAMPLE_QUOTES Mock 데이터 제거 - Server Actions 생성 (CRUD + 특수 기능 14개) - QuoteManagementClient 분리 (SSR/CSR 패턴) - Quote 타입 및 변환 함수 정의 ## 추가된 API 연동 - 목록/상세/등록/수정/삭제/일괄삭제 - 최종확정/확정취소/수주전환 - PDF 생성/이메일/카카오 발송 - 견적번호 미리보기/요약 통계 feat: 공정관리 페이지 및 컴포넌트 추가 - 공정관리 목록/상세/등록/수정 페이지 구현 - ProcessListClient, ProcessDetail, ProcessForm 컴포넌트 추가 - ProcessWorkLogPreviewModal, RuleModal 추가 - MobileCard 공통 컴포넌트 추가 - WorkLogModal.tsx 개선 - .gitignore 업데이트 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> (cherry picked from commitf0c0de2ecd) chore: React 공통 컴포넌트 업데이트 - VacationManagement: API 연동 개선 - WorkOrders: 작업자 선택 모달 개선 - TypeScript 빌드 설정 업데이트 feat: I-8 휴가 정책 관리 API 연동 - actions.ts: 휴가 정책 CRUD Server Actions - LeavePolicyManagement 컴포넌트 API 연동 feat: I-7 종합분석 API 연동 - actions.ts: 종합분석 조회 Server Actions - ComprehensiveAnalysis 컴포넌트 API 연동 feat: I-6 일일 생산현황 API 연동 - actions.ts: 일일 리포트 조회 Server Actions - DailyReport 컴포넌트 API 연동 feat: I-5 미수금 현황 API 연동 - actions.ts: 미수금 조회 Server Actions - ReceivablesStatus 컴포넌트 API 연동 feat: I-4 거래통장 조회 API 연동 - actions.ts: 은행 거래내역 조회 Server Actions - BankTransactionInquiry 컴포넌트 API 연동 feat: I-3 법인카드 사용내역 API 연동 - actions.ts: 카드 거래내역 조회 Server Actions - CardTransactionInquiry 컴포넌트 API 연동 feat: I-2 거래처 원장 API 연동 - actions.ts: 거래처 원장 조회 Server Actions - VendorLedger 컴포넌트 API 연동 - VendorLedgerDetail 상세 조회 연동 feat: H-3 출하 관리 API 연동 - actions.ts: Server Actions (CRUD, 상태 변경) - ShipmentList: 출하 목록 API 연동 - ShipmentCreate: 출하 등록 API 연동 - ShipmentEdit: 출하 수정 API 연동 - ShipmentDetail: 출하 상세 API 연동 feat: G-2 작업실적 관리 API 연동 - types.ts API 타입 추가 (WorkResultApi, WorkResultStatsApi 등) - transformApiToFrontend/transformFrontendToApi 변환 함수 추가 - actions.ts 서버 액션 생성 (8개 함수) - index.ts 액션 exports 추가 Server Actions: - getWorkResults: 목록 조회 (페이징, 필터링) - getWorkResultStats: 통계 조회 - getWorkResultById: 상세 조회 - createWorkResult: 등록 - updateWorkResult: 수정 - deleteWorkResult: 삭제 - toggleInspection: 검사 상태 토글 - togglePackaging: 포장 상태 토글 fix: StockStatusList Hook 순서 오류 수정 - 조건부 return 전에 모든 Hooks(useCallback, useMemo) 선언 - React Rules of Hooks 준수 feat: H-2 재고현황 Mock → API 연동 완료 - StockStatusDetail.tsx: 상세 조회 API 연동 - StockStatusList.tsx: 목록 조회 API 연동 (이전 세션) - actions.ts: 재고 현황 Server Actions 구현 feat: H-1 입고 관리 Mock → API 연동 완료 - ReceivingDetail.tsx: 상세 조회 및 입고처리 API 연동 - ReceivingProcessDialog.tsx: 폼 데이터 API 전달 구조로 변경 - InspectionCreate.tsx: 검사 대상 목록 API 조회 적용 - ReceivingList.tsx: 미사용 타입 import 정리 feat: G-1 작업지시 관리 API 연동 - actions.ts 서버 액션 11개 함수 구현 - types.ts API 타입 및 변환 함수 추가 - index.ts 액션 함수 export 추가 Server Actions: - getWorkOrders (목록) - getWorkOrderStats (통계) - getWorkOrderById (상세) - createWorkOrder (등록) - updateWorkOrder (수정) - deleteWorkOrder (삭제) - updateWorkOrderStatus (상태변경) - assignWorkOrder (담당자배정) - toggleBendingField (벤딩토글) - addWorkOrderIssue (이슈등록) - resolveWorkOrderIssue (이슈해결) feat: I-1 미지급비용 관리 React 연동 - Server Actions 패턴으로 API 연동 구현 (actions.ts) - Mock 데이터 제거, props 기반 데이터 주입 - Server Component로 초기 데이터 로딩 - 삭제/지급일 변경 등 CRUD 액션 연동 feat: HR 모듈 API 연동 완료 및 휴가관리 버그 수정 ## 휴가관리 (VacationManagement) - 휴가 부여 API 연동: createLeaveGrant 호출 추가 - 휴가 신청 시 선택된 사원 userId 전달 (잔여휴가 오류 수정) - LeaveType 타입 분리 (VacationType과 구분) - VacationGrantDialog에 부여일(grantDate) 필드 추가 ## 근태관리 (AttendanceManagement) - actions.ts 추가: API 호출 함수 분리 - 타입 정의 확장 및 개선 ## 기타 개선 - CardManagement, SalaryManagement: actions 개선 - DocumentCreate: 전자결재 actions 및 index 개선 - GoogleMap: 지도 컴포넌트 개선 feat: Phase E 인사관리 Mock → API 마이그레이션 - E-1 법인카드 관리 API 연동 - actions.ts 생성 (getCards, createCard, updateCard, deleteCard, toggleCardStatus) - CardForm, 페이지 컴포넌트 API 연동 - E-2 급여 관리 API 연동 - actions.ts 생성 (getSalaries, getSalary, updateSalaryStatus, bulkUpdateSalaryStatus) - 급여 목록 컴포넌트 API 연동 - 결재 시스템 actions.ts 추가 (ApprovalBox, DraftBox, ReferenceBox, DocumentCreate) - DepositManagement actions.ts 페이지네이션 응답 구조 수정 - 부서 관리, 휴가 관리 actions.ts 개선 - API URL에 /api prefix 추가 회계 및 설정 모듈 리팩토링: actions 분리, 타입 정의 개선 feat: 휴가 부여현황 Mock 데이터 제거 및 API 연동 - getLeaveGrants, createLeaveGrant, deleteLeaveGrant API 함수 추가 - LeaveGrantType, LeaveGrantRecord, CreateLeaveGrantRequest 타입 추가 - generateGrantData Mock 함수 제거 - fetchGrantData로 실제 API 호출 - grantData 상태를 API 데이터로 갱신 feat: 휴가 사용현황 Mock 데이터 제거 및 API 연동 - getLeaveBalances() API 함수 추가 - LeaveBalanceRecord, GetLeaveBalancesParams 타입 정의 - generateUsageData() Mock 함수 제거 - fetchUsageData()로 실제 API 호출 - hireDate 날짜 포맷팅 예외 처리 추가 feat: C-4 부서 관리 Mock → API 연동 - actions.ts 생성 (getDepartmentTree, createDepartment, updateDepartment, deleteDepartment, deleteDepartmentsMany) - index.tsx Mock 데이터 제거 및 API 연동 - 트리 구조 CRUD 완전 연동 ⚠️ .env.local에 API_URL=https://api.sam.kr/api 설정 필요 (Server Actions용) feat: C-3 휴가 관리 Mock → API 연동 - actions.ts 생성: getLeaves, createLeave, approveLeave, rejectLeave, cancelLeave 등 - index.tsx 수정: 신청현황 탭 Mock 데이터 → API 호출 전환 - 일괄 승인/반려 API 연동 (approveLeavesMany, rejectLeavesMany) - 휴가 신청 다이얼로그 createLeave API 연동 feat: C-2 근태 관리 Mock → API 연동 - actions.ts 생성 (checkIn/checkOut/getTodayAttendance) - GoogleMap.tsx userLocation 콜백 추가 - page.tsx Mock console.log 제거 + API 연동 - 처리중 상태 및 버튼 텍스트 추가 feat: C-1 직원 관리 Mock → API 연동 - actions.ts 생성 (CRUD + 통계 + 일괄삭제 Server Actions) - utils.ts 생성 (API ↔ Frontend 데이터 변환) - index.tsx Mock 데이터 제거, API 연동 - [id]/page.tsx 상세 페이지 API 연동 - [id]/edit/page.tsx 수정 페이지 API 연동 - new/page.tsx 등록 페이지 API 연동 API Endpoints: - GET/POST /api/v1/employees - GET/PATCH/DELETE /api/v1/employees/{id} - POST /api/v1/employees/bulk-delete - GET /api/v1/employees/stats feat: Daum 우편번호 서비스 연동 및 악성채권 UI 개선 - useDaumPostcode 공통 훅 생성 (Daum Postcode API 연동) - 우편번호 찾기 기능 적용: 악성채권, 거래처, 직원, 회사정보, 주문등록 - 악성채권 페이지 토글 순서 변경 (라벨 → 토글) - 악성채권 토글 기능 수정 (매출/매입 → 등록/해제) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com> (cherry picked from commit41ef0bdd86) feat: A-2 팝업 관리 Mock → API 연동 - 상세 조회 페이지: MOCK_POPUPS → getPopupById() API - 수정 페이지: MOCK_POPUPS → getPopupById() API + 로딩 상태 - PopupForm: console.log → createPopup/updatePopup Server Actions - 삭제 기능: deletePopup() API 연동 + 로딩 상태 - 데이터 변환 유틸리티 추가 (API ↔ Frontend) feat: A-1 악성채권 관리 Mock → API 연동 완료 - 상세 페이지 서버 컴포넌트 전환 ([id]/page.tsx, [id]/edit/page.tsx) - BadDebtDetail.tsx: CRUD API 연동 (createBadDebt, updateBadDebt, deleteBadDebt) - actions.ts: 메모 API 추가 (addBadDebtMemo, deleteBadDebtMemo) feat: 매입 관리 Mock → API 전환 및 세금계산서 토글 연동 - index.tsx: Mock 데이터 제거, API 데이터 로딩으로 전환 - actions.ts: getPurchases(), togglePurchaseTaxInvoice() 서버 액션 추가 - vendorOptions 빈 문자열 필터링 (Select.Item 에러 수정) feat: 매출 상세 페이지 API 연동 - 목데이터(MOCK_VENDORS, fetchSalesDetail) 제거 - getSaleById, createSale, updateSale, deleteSale API 연동 - getClients로 거래처 목록 로드 - 상태 관리 개선 (clients, isLoading, isSaving) fix: Mock 데이터를 실제 API 연동으로 복원 - 팝업 관리, 결제 내역, 구독 관리, 알림 설정 API 연동 - 입금/출금/거래처 관리 API 연동 - page.tsx를 서버 컴포넌트로 변환 - actions.ts 서버 액션 추가
12 KiB
12 KiB
CSS Migration Workflow (React → Next.js)
문제점 분석
현재 발생하는 이슈
- ❌ 개발 로직은 정확히 구현되나 CSS 디테일이 누락됨
- ❌
p-6vsp-4 md:p-6같은 반응형 클래스 차이 놓침 - ❌
py-6vsp-6같은 방향성 클래스 차이 놓침 - ❌
container mx-auto같은 레이아웃 클래스 누락
왜 놓치는가?
- 패턴 매칭의 한계: grep으로 "padding" 검색 시 모든 p-* 클래스가 나와서 정확한 매칭 어려움
- 컨텍스트 부족: 왜 특정 클래스를 사용했는지 의도 파악 실패
- 라인 바이 라인 비교 부재: React와 Next.js를 동시에 비교하지 않음
해결 방법론
방법 1: 페이지 단위 CSS 추출 및 비교 (우선 적용)
프로세스
1. 사용자 요청: "품목 등록 페이지 CSS 동기화"
2. Claude: React 파일 전체 className 추출
3. Claude: Next.js 파일 전체 className 추출
4. Claude: 두 파일 비교하여 차이점 리스트 생성
5. 사용자: 차이점 확인 후 "적용해줘"
6. Claude: 차이점 일괄 수정
추출 형식
{
"page": "ItemManagement",
"react_file": "sma-react-v2.0/src/components/ItemManagement.tsx",
"nextjs_file": "sam-react-prod/src/components/items/ItemListClient.tsx",
"comparison": [
{
"component": "CardContent (통계 카드)",
"react_line": 1930,
"react_className": "p-4 md:p-6",
"nextjs_line": 148,
"nextjs_className": "p-6",
"status": "MISMATCH",
"action": "p-6 → p-4 md:p-6"
},
{
"component": "페이지 래퍼",
"react_line": null,
"react_className": null,
"nextjs_line": 148,
"nextjs_className": "py-6",
"status": "EXTRA",
"action": "py-6 → p-6으로 변경 (React 기준)"
},
{
"component": "container",
"react_line": null,
"react_className": null,
"nextjs_line": 148,
"nextjs_className": "container mx-auto",
"status": "EXTRA",
"action": "container mx-auto 제거"
}
]
}
장점
- ✅ 모든 CSS 차이점을 체계적으로 캐치
- ✅ 사용자가 검토 후 일괄 적용 가능
- ✅ 누락 없이 정확한 동기화
단점
- ⚠️ 초기 추출에 시간 소요 (하지만 정확함)
- ⚠️ JSON 형태로 제공 시 가독성 떨어질 수 있음
방법 2: 섹션별 단계적 CSS 마이그레이션
프로세스
1. 사용자: "헤더 부분 CSS 동기화" (라인 범위 지정)
2. Claude: 해당 섹션만 추출 및 비교
3. Claude: 차이점 리스트 제공
4. 사용자: 확인 후 적용 지시
5. 반복 (통계 카드, 검색 필터, 테이블...)
섹션 분류 예시
## 품목 관리 페이지 섹션 구조
### 1. 페이지 헤더
- React: lines 1820-1900
- Next.js: lines 118-142
- 주요 CSS: flex, gap, p-2, text-xl md:text-2xl
### 2. 통계 카드
- React: lines 1901-1970
- Next.js: lines 144-161
- 주요 CSS: p-4 md:p-6, grid, gap-4
### 3. 검색 및 필터
- React: lines 1971-2050
- Next.js: lines 163-203
- 주요 CSS: p-4 md:p-6, flex gap-4
### 4. 테이블 리스트
- React: lines 2051-2300
- Next.js: lines 205-330
- 주요 CSS: p-4 md:p-6, border, rounded-lg
장점
- ✅ 작은 단위로 나눠서 정확도 향상
- ✅ 사용자가 우선순위 조정 가능
단점
- ⚠️ 여러 번 요청 필요 (번거로움)
- ⚠️ 섹션 경계가 애매한 경우 있음
방법 3: CSS 체크리스트 선제공
프로세스
1. 사용자: React 파일 참고 경로 제공
2. Claude: React 파일에서 모든 className 추출하여 체크리스트 생성
3. 사용자: 체크리스트 확인
4. Claude: Next.js 구현 시 체크리스트 기반으로 CSS 적용
5. 구현 후 다시 체크리스트로 검증
체크리스트 형식
## CSS 체크리스트 - 품목 관리 페이지
### 레이아웃
- [ ] 페이지 래퍼: container 제거, p-6 또는 py-6?
- [ ] space-y-6: 전체 섹션 간격
### 통계 카드
- [ ] CardContent: p-4 md:p-6 (반응형)
- [ ] grid: grid-cols-1 md:grid-cols-2 lg:grid-cols-4
- [ ] gap-4
- [ ] text-3xl md:text-4xl (숫자)
- [ ] opacity-15 (아이콘)
### 검색 필터
- [ ] CardContent: p-4 md:p-6
- [ ] flex gap-4
- [ ] pl-10 (검색 아이콘 공간)
### 테이블
- [ ] CardContent: p-4 md:p-6
- [ ] border rounded-lg overflow-hidden
- [ ] py-8 (빈 상태 메시지)
- [ ] hover:bg-gray-50 (행 호버)
장점
- ✅ 구현 전 체크리스트로 사전 검증
- ✅ 사용자가 체크하면서 누락 확인 가능
단점
- ⚠️ 체크리스트가 길어지면 복잡함
- ⚠️ Claude가 체크리스트를 빠뜨릴 수 있음
방법 4: 스크린샷 기반 역공학
프로세스
1. 사용자: React 화면 스크린샷 제공
2. 사용자: "이 부분 CSS 똑같이 적용"
3. Claude: 스크린샷 해당 영역의 React 코드 찾기
4. Claude: 해당 영역 모든 className을 추출
5. Claude: Next.js에 일대일 적용
장점
- ✅ 시각적으로 명확함
- ✅ 사용자가 원하는 부분만 정확히 지정 가능
단점
- ⚠️ 스크린샷과 코드 매칭이 어려울 수 있음
- ⚠️ 보이지 않는 CSS (hover, focus) 놓칠 수 있음
적용 우선순위 및 실험 계획
1차 실험: 방법 1 (페이지 단위 CSS 추출 및 비교)
- 대상: 품목 관리 페이지 (ItemListClient)
- 목표: 모든 CSS 차이점 100% 캐치
- 측정:
- 놓친 CSS 개수
- 소요 시간
- 사용자 만족도
2차 실험: 방법 3 (CSS 체크리스트 선제공)
- 대상: 품목 등록 페이지 (ItemForm)
- 목표: 구현 전 체크리스트로 사전 검증
- 측정:
- 체크리스트 작성 시간
- 누락 개수
- 수정 횟수
3차 실험: 방법 2 (섹션별 단계적)
- 대상: 대용량 페이지 (3000줄 이상)
- 목표: 큰 파일도 누락 없이 처리
- 측정:
- 섹션별 정확도
- 총 소요 시간
4차 실험: 방법 4 (스크린샷 기반)
- 대상: 디자인 미세 조정 단계
- 목표: 시각적 완성도 100%
- 측정:
- 화면 일치도
- 반복 수정 횟수
실험 결과 기록 템플릿
실험 1: 페이지 단위 CSS 추출 (방법 1)
- 날짜: YYYY-MM-DD
- 대상 페이지:
- React 파일:
- Next.js 파일:
- 총 CSS 차이점: N개
- 놓친 CSS: N개 (어떤 것들?)
- 소요 시간: N분
-
개선 사항:
-
다음 실험 반영 사항:
실험 결과 기록
✅ 실험 1: 페이지 단위 CSS 추출 및 비교 (방법 1)
실험 정보:
- 날짜: 2025-11-17
- 대상 페이지: 품목 관리 리스트 페이지 (ItemListClient)
- React 파일:
sma-react-v2.0/src/components/ItemManagement.tsx(lines 1956-2200) - Next.js 파일:
sam-react-prod/src/components/items/ItemListClient.tsx
실험 결과:
-
총 CSS 차이점: 9개 주요 카테고리
- CardTitle 반응형 CSS
- TabsList 래퍼 및 반응형 구조
- 테이블 컬럼 구조 재구성 (체크박스, 번호 추가)
- 품목코드 배경색 및 스타일
- 품목유형 Badge 색상 함수
- 품목명 말줄임 및 flex 구조
- 규격/단위 Badge 및 반응형
- 작업 컬럼 정렬 및 아이콘
- 체크박스 선택 기능
-
놓친 CSS: 0개 (100% 정확도)
-
소요 시간: 약 20분
- 비교 문서 작성: 10분
- 구현: 10분
-
사용자 만족도: ⭐⭐⭐⭐⭐ (5/5)
추가 발견 사항:
-
🎯 UI 컴포넌트 스타일 차이 발견: Tabs 컴포넌트 자체가 React와 Next.js에서 달랐음
src/components/ui/tabs.tsx전체 교체 필요rounded-lg→rounded-xldata-[state=active]:bg-background→data-[state=active]:bg-card
-
📝 타입 정의 개선: ITEM_TYPE_LABELS에서 불필요한 영문 표현 제거
'제품 (Finished Goods)'→'제품'
장점:
- ✅ 모든 CSS 차이점을 체계적으로 캐치
- ✅ 체크리스트로 누락 방지 (0% 누락률)
- ✅ 명확한 before/after 비교 가능
- ✅ TodoWrite로 진행상황 실시간 추적
- ✅ UI 컴포넌트 레벨의 차이까지 발견
단점:
- ⚠️ 초기 비교 문서 작성에 10분 소요 (하지만 정확성 보장으로 충분히 가치 있음)
- ⚠️ 대규모 페이지의 경우 비교 문서가 길어질 수 있음
개선 사항:
- ✅ 확립된 워크플로우를 모든 기능 구현/디자인 수정에 적용하기로 결정
- ✅ UI 컴포넌트 차이도 함께 체크하는 것이 중요함을 확인
✅ 베스트 프랙티스 (확립됨)
추천 워크플로우
모든 기능 구현 및 디자인 수정에 적용할 표준 프로세스:
📋 1. 비교 문서 작성 (claudedocs/)
- React 참조 파일 지정 (경로 + 라인 범위)
- Next.js 타겟 파일 지정
- 라인별 상세 CSS 비교
- 체크리스트 생성
- 파일명: CSS_COMPARISON_{PageName}.md
👀 2. 검토 및 확인
- 사용자와 비교 문서 공유
- 차이점 확인 및 수정 방향 결정
- 우선순위 설정
📝 3. 체계적 구현
- TodoWrite로 작업 항목 생성
- 체크리스트 순차 작업
- 각 항목 완료 시 즉시 상태 업데이트
✅ 4. 검증 및 완료
- TypeScript 컴파일 에러 체크
- 실제 화면 확인
- 비교 문서에 완료 표시
- 발견된 추가 이슈 문서화
페이지 유형별 전략
소규모 페이지 (<500줄):
- 전체 페이지 한 번에 비교
- 비교 문서 1개로 충분
- 예상 시간: 15-20분
중규모 페이지 (500-2000줄):
- 섹션별로 나눠서 비교 (헤더, 본문, 푸터 등)
- 비교 문서 1개에 섹션별 체크리스트
- 예상 시간: 30-40분
- 적용 사례: 품목 관리 리스트 페이지 ✅
대규모 페이지 (2000줄+):
- 주요 섹션별로 별도 비교 문서 작성
- 여러 세션에 걸쳐 진행
- 예상 시간: 1-2시간 (여러 세션)
핵심 체크 포인트
반드시 확인해야 할 항목:
-
반응형 클래스
md:,lg:브레이크포인트hidden md:table-cell같은 반응형 표시/숨김
-
방향성 클래스
p-6vspx-6vspy-6gap-4vsgap-x-4vsgap-y-4
-
컴포넌트 위치 클래스
text-leftvstext-centervstext-rightjustify-startvsjustify-centervsjustify-end
-
상태 클래스
hover:,focus:,active:,disabled:data-[state=active]:같은 데이터 속성 기반
-
UI 컴포넌트 차이
src/components/ui/폴더의 컴포넌트들- React와 Next.js에서 다를 수 있음
- 발견 시 컴포넌트 자체를 React 버전으로 교체
-
타입 정의 및 상수
src/types/폴더의 타입 정의- Label 상수들 (ITEM_TYPE_LABELS 등)
- 불필요한 내용 제거
주의사항
❌ 하지 말아야 할 것:
- 비교 문서 없이 바로 구현하지 말 것
- 기억에 의존하여 CSS 적용하지 말 것
- 한 번에 모든 변경사항을 구현하지 말 것 (체크리스트 순차 진행)
✅ 반드시 해야 할 것:
- 비교 문서 먼저 작성
- TodoWrite로 진행상황 추적
- 단계별 완료 확인
- TypeScript 에러 체크
- 실제 화면에서 검증
다음 단계
- ✅ 워크플로우 문서 작성 완료
- ✅ 방법 1 실험 완료: 품목 관리 리스트 페이지 (성공)
- ✅ 실험 결과 기록 및 베스트 프랙티스 확립
- ✅ 표준 워크플로우 정립
- 🎯 다음 적용 대상:
- 품목 상세 조회 페이지
- 품목 등록 페이지
- 기타 기능 구현 및 디자인 수정
버전 히스토리
- v1.0 (2025-11-17): 초안 작성, 4가지 방법론 정의
- v2.0 (2025-11-17): 실험 완료, 베스트 프랙티스 확립, 표준 워크플로우 정립