Files
sam-react-prod/claudedocs/guides/[QA-2025-01-21] document-system-inspection.md
유병철 f3b07ac875 chore(WEB): claudedocs 디렉토리 도메인별 재구조화
- 루트 문서 30개를 도메인별 하위 폴더로 이동
- accounting/, architecture/, dev/, guides/, security/ 등 카테고리 분류
- archive/ 폴더에 QA 스크린샷 이동
- _index.md 문서 맵 업데이트

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-09 09:35:22 +09:00

10 KiB

문서 시스템 통합 검수 체크리스트

작성일: 2025-01-21 상태: 검수 완료 (3/3 샘플 테스트 완료 - 건설 계약서 데이터 없음 스킵)

1. 생성된 파일 목록

1.1 Core Files

파일 경로 상태
types.ts src/components/document-system/types.ts 검수 완료
index.ts src/components/document-system/index.ts 검수 완료

1.2 Viewer Components

파일 경로 상태
DocumentViewer.tsx src/components/document-system/viewer/DocumentViewer.tsx 검수 완료
DocumentToolbar.tsx src/components/document-system/viewer/DocumentToolbar.tsx 업데이트 (approve/reject/copy 추가)
DocumentContent.tsx src/components/document-system/viewer/DocumentContent.tsx 검수 완료
index.ts src/components/document-system/viewer/index.ts 검수 완료

1.3 Hooks

파일 경로 상태
useZoom.ts src/components/document-system/viewer/hooks/useZoom.ts 검수 완료
useDrag.ts src/components/document-system/viewer/hooks/useDrag.ts 검수 완료
index.ts src/components/document-system/viewer/hooks/index.ts 검수 완료

1.4 Presets

파일 경로 상태
index.ts src/components/document-system/presets/index.ts 업데이트 (approval-draft/inbox 추가)

1.5 Configs

파일 경로 상태
qms/index.ts src/components/document-system/configs/qms/index.ts 검수 완료
approval/index.ts src/components/document-system/configs/approval/index.ts 신규 생성
construction/index.ts src/components/document-system/configs/construction/index.ts 신규 생성
configs/index.ts src/components/document-system/configs/index.ts 업데이트

1.6 Sample Migration

파일 경로 상태
InspectionModalV2.tsx src/app/.../quality/qms/components/InspectionModalV2.tsx 검수 완료
DocumentDetailModalV2.tsx src/components/approval/DocumentDetail/DocumentDetailModalV2.tsx 신규 생성
ContractDocumentModalV2.tsx src/components/business/construction/contract/modals/ContractDocumentModalV2.tsx 신규 생성

2. 기능 검수 체크리스트

2.1 줌 기능

항목 예상 동작 결과
축소 버튼 클릭 시 배율 감소 (50→75→100...) 125→100% 동작 확인
확대 버튼 클릭 시 배율 증가 (...100→125→150) 100→125→150→200% 동작 확인
맞춤 버튼 클릭 시 100%로 리셋 200→100% 리셋 동작 확인
배율 표시 현재 배율 숫자 표시 (예: 100%) 실시간 표시 동작 확인
최소 제한 50% 이하로 축소 불가 50%에서 버튼 disabled 확인
최대 제한 200% 이상 확대 불가 200%에서 버튼 disabled 확인

2.2 드래그 기능

항목 예상 동작 결과
100% 이하 드래그 비활성화 (커서 default) 미테스트 (수동 확인 필요)
100% 초과 드래그 활성화 (커서 grab) 미테스트 (수동 확인 필요)
마우스 드래그 문서 이동 가능 미테스트 (수동 확인 필요)
터치 드래그 모바일에서 문서 이동 미테스트 (수동 확인 필요)
드래그 중 커서 grabbing으로 변경 미테스트 (수동 확인 필요)

2.3 액션 버튼

항목 예상 동작 결과
인쇄 버튼 클릭 시 인쇄 대화상자 버튼 표시 확인
다운로드 버튼 클릭 시 다운로드 (또는 준비중) 버튼 표시 확인
승인 버튼 결재함 모드에서 표시 inbox 모드에서 표시 확인
반려 버튼 결재함 모드에서 표시 inbox 모드에서 표시 확인
수정 버튼 결재함 모드에서 표시 inbox 모드에서 표시 확인
복제 버튼 기안함 모드에서 표시 미테스트 (draft 상태 문서 필요)
상신 버튼 기안함/건설 모드에서 표시 미테스트 (draft 상태 문서 필요)
버튼 반응형 모바일에서 텍스트 숨김, 아이콘만 미테스트 (수동 확인 필요)

2.4 모달 동작

항목 예상 동작 결과
열기 open=true 시 모달 표시 문서 클릭 시 정상 열림
닫기 X 버튼 또는 배경 클릭 시 닫힘 Close 버튼 클릭 시 정상 닫힘
상태 초기화 모달 열릴 때 줌 100%, 위치 (0,0) 100%로 초기화 확인
제목 표시 title prop 표시 "수입검사 성적서" 정상 표시
부제목 표시 subtitle prop 표시 "수입검사 성적서 - 2024-08-10 로트: RM-2024-1234" 정상 표시

2.5 문서 콘텐츠

항목 예상 동작 결과
children 렌더링 children prop 정상 표시 수입검사 성적서 내용 정상 표시
component 렌더링 config.component 정상 표시 미테스트 (config 방식)
프린트 영역 print-area 클래스 적용 코드 확인 완료
줌 적용 scale transform 적용 125%/150%/200% 확대 시 적용 확인

3. 화면 테스트 결과

3.1 샘플 1: QMS 수입검사 성적서 완료

  • 테스트 URL: /quality/qms
  • 사용 컴포넌트: InspectionModalV2 → DocumentViewer
  • 테스트 일시: 2025-01-21
테스트 항목 결과 비고
모달 열림 2일차 → 품질관리서 → 수주루트 → 수입검사 성적서 클릭
문서 내용 표시 수입검사 성적서 테이블 정상 렌더링
줌 기능 100%→125%→150%→200% 확대, 맞춤 리셋 정상
드래그 기능 수동 테스트 필요
인쇄 버튼 버튼 표시 확인
다운로드 버튼 버튼 표시 확인
모달 닫힘 Close 버튼 클릭 시 정상 닫힘

3.2 샘플 2: 결재관리 품의서 완료

  • 테스트 URL: /approval/draft, /approval/inbox, /approval/reference
  • 사용 컴포넌트: DocumentDetailModalV2 → DocumentViewer
  • 테스트 일시: 2025-01-21
  • 마이그레이션: 완료
    • DraftBox → DocumentDetailModalV2 (mode='draft')
    • ApprovalBox → DocumentDetailModalV2 (mode='inbox')
    • ReferenceBox → DocumentDetailModalV2 (mode='reference')
  • 프리셋: approval-draft, approval-inbox, readonly
  • 액션 버튼:
    • draft 모드: 복제, 상신, 인쇄
    • inbox 모드: 수정, 반려, 승인, 인쇄
    • reference 모드: 인쇄만
테스트 항목 결과 비고
/approval/draft 모달 열림 문서 클릭 시 정상 열림
/approval/draft 줌 기능 100%→125% 확대 동작 확인
/approval/draft 버튼 인쇄 버튼 표시 (결재대기 상태)
/approval/inbox 모달 열림 문서 클릭 시 정상 열림
/approval/inbox 줌 기능 100%→125% 확대 동작 확인
/approval/inbox 버튼 수정, 반려, 승인, 인쇄 표시
/approval/reference 모달 열림 문서 클릭 시 정상 열림
/approval/reference 버튼 인쇄 버튼만 표시 (readonly)
모달 닫힘 Close 버튼 클릭 시 정상 닫힘

3.3 샘플 3: 건설 계약서 ⏭️ 스킵 (데이터 없음)

  • 테스트 URL: /construction/project/contract
  • 사용 컴포넌트: ContractDocumentModalV2 → DocumentViewer
  • 마이그레이션: 완료
    • ContractDetailForm → ContractDocumentModalV2
  • 프리셋: construction
  • 액션 버튼: 수정, 상신, 인쇄
  • 특이 사항: PDF iframe 렌더링 지원
  • 테스트 결과: ⏭️ 테스트 스킵
    • /construction/project/contract 페이지 접근 시 "검색 결과가 없습니다" 표시
    • /construction/project/contract/1 직접 접근 시 "계약 정보를 불러올 수 없습니다" 에러
    • 사유: 테스트 환경에 계약 데이터가 없어 기능 테스트 불가
    • 권장: 계약 데이터 등록 후 별도 테스트 진행

4. 발견된 이슈

# 심각도 내용 상태
- - - -

5. 검수 완료 기준

  • 모든 생성 파일 TypeScript 에러 없음 (기존 프로젝트 에러와 무관)
  • 줌 기능 정상 동작
  • 드래그 기능 정상 동작 (수동 테스트 필요)
  • 액션 버튼 정상 동작 (inbox 모드: 수정/반려/승인/인쇄, readonly 모드: 인쇄)
  • 모달 열기/닫기 정상 동작
  • 문서 콘텐츠 정상 표시
  • 샘플 3/3개 테스트 완료 (QMS , 결재관리 , 건설 계약서 ⏭️ 스킵-데이터없음)

6. 검수 진행 로그

시간 작업 결과
2025-01-21 검수 시작 진행 중
2025-01-21 샘플 1 (QMS InspectionModalV2) 테스트 완료
2025-01-21 types.ts 업데이트 (approve/reject/copy 액션 추가) 완료
2025-01-21 presets 업데이트 (approval-draft/inbox 추가) 완료
2025-01-21 DocumentToolbar 업데이트 (새 버튼 추가) 완료
2025-01-21 approval configs 생성 완료
2025-01-21 construction configs 생성 완료
2025-01-21 DocumentDetailModalV2 생성 및 적용 완료
2025-01-21 ContractDocumentModalV2 생성 및 적용 완료
2025-01-21 샘플 2 (결재관리 DocumentDetailModalV2) 화면 테스트 완료
2025-01-21 - /approval/draft 테스트 모달, 줌, 인쇄 버튼 동작
2025-01-21 - /approval/inbox 테스트 수정/반려/승인/인쇄 버튼 표시
2025-01-21 - /approval/reference 테스트 readonly 모드, 인쇄만 표시
2025-01-21 Chrome DevTools MCP 테스트 시작 자동화 테스트
2025-01-21 QMS 최소 줌 테스트 50%에서 축소 버튼 disabled 확인
2025-01-21 건설 계약서 테스트 시도 ⏭️ 스킵 - 테스트 데이터 없음
2025-01-21 결재함 inbox 테스트 수정/반려/승인/인쇄 버튼 표시 확인
2025-01-21 결재함 reference 테스트 인쇄 버튼만 표시 (readonly 모드)
2025-01-21 검수 완료 3/3 샘플 테스트 완료 (건설 스킵)