7.7 KiB
7.7 KiB
Superport v2 프론트엔드 구현 Task List (UI First → API Integration)
본 체크리스트는 PRD(doc/PRD_입출고_결재_v2.md)를 기준으로 shadcn_ui 스타일과 반응형 패턴을 준수하여 화면을 구현하기 위한 단계별 작업 목록입니다. 작업 순서는 ① 코드 시작 전 최종 확인 → ② UI 스캐폴딩/상호작용 구현 → ③ 실제 API 연동(Dio/ApiClient/DI)입니다. Mock 데이터는 사용하지 않습니다.
0) 코드 시작 전 최종 확인(Repository/환경)
- Flutter 버전/채널 확인,
flutter pub get pubspec.yaml확인:go_router,shadcn_ui,intl,two_dimensional_scrollables,lucide_icons_flutter포함Environment.initialize()호출 및.env.development/.env.production에서API_BASE_URL/TIMEOUT_MS/LOG_LEVEL로드- 라우팅 스켈레톤(go_router) 구성: 로그인/대시보드/입·출·대여/마스터/결재/보고서
- 글로벌 테마/ShadTheme 확인(폰트/간격/배지/버튼 일관)
1) 공통 컴포넌트/레이아웃(UI)
- AppLayout(좌 사이드바/상단 헤더/본문) 적용, 브레드크럼·타이틀·툴바 영역 정리
- 테이블:
ShadTable.list표준화(고정 헤더/가로 스크롤/소팅/페이지네이션 UI만) - 모달:
SuperportShadDialog(헤더/본문/푸터 분리, 모바일 풀스크린) 공통 wrapper - 입력 위젯:
ShadInput/Select/Switch,SuperportShadDatePicker/RangePicker적용 가이드 - 필터바(검색/기간/상태/창고/Reset) 공통 위젯
- 반응형 프리셋: 데스크톱/태블릿/모바일 열 가시성 설정(섹션 12 규칙 반영)
- 토스트/스낵바/스켈레톤/Empty 상태 공통 처리
2) 인증/대시보드(UI)
- 로그인 화면(
/login): 아이디/비밀번호 UI(제출/로딩/에러 표시 흐름) - 대시보드(
/): KPI 카드, 최근 트랜잭션, 내 결재 대기 리스트 — 스켈레톤/Empty 상태 구현
3) 입고(/inbounds) UI
- 라우트/네비게이션 연결
- 목록 테이블: 번호/처리일자/창고/트랜잭션번호/상태/작성자/품목수/총수량/비고
- 필터: 기간/창고/상태/검색, 소팅/페이지네이션
- 신규 모달: 헤더(처리일자/창고/상태/작성자/비고) + 시스템 필드(
transaction_type_id=입고RO/숨김) - 라인 테이블: 제품(자동완성)→제조사/단위 자동, 수량/단가/비고, (+)/(−) 행 편집
- 검증: 필수/수량>=1/단가>=0, 상단 요약 + 인라인 에러
- 수정 모달: 작성자/트랜잭션번호 RO, 종결 상태 수정 제한
4) 출고(/outbounds) UI
- 목록 테이블: 번호/처리일자/창고/트랜잭션번호/상태/작성자/고객수/품목수/총수량/비고
- 필터: 기간/창고/상태/고객/검색
- 신규/수정 모달: 헤더(…)+ 시스템 필드(
transaction_type_id=출고RO/숨김) - 고객 연결(멀티): 고객사 자동완성 → 토큰/칩 UI, 최소 1건 검증
- 라인 테이블: 제품/제조사RO/단위RO/수량/단가/비고
5) 대여(/rentals) UI
- 목록 테이블: 번호/처리일자/창고/대여구분/트랜잭션번호/상태/반납예정일/고객수/품목수/비고
- 필터: 기간/창고/상태/대여구분/반납예정일 범위/검색
- 신규/수정 모달: 헤더(…/대여구분/반납예정일) + 시스템 필드(
transaction_type_id대여/반납 자동 매핑) - 고객 연결(멀티) + 라인 테이블(입고·출고와 동일)
- 규칙: 대여구분은 종결 후 변경 불가, 반납예정일은 진행 중 수정 가능
6) 마스터(UI)
- 벤더: 목록/필터(q/사용여부), 신규/수정(코드RO), 삭제/복구 UI
- 제품: 목록/필터(q/제조사/단위/사용), 신규/수정(코드RO)
- 창고: 목록/필터(q/사용), 신규/수정(우편번호 검색 모달 UI 연동)
- 고객사: 목록/필터(q/유형/사용), 신규/수정(유형→is_partner/is_general 매핑 UI)
- 사용자: 목록/필터(q/그룹/사용), 신규/수정(사번RO)
- 그룹: 목록/필터(q/기본/사용), 신규/수정(그룹명RO)
- 메뉴: 목록/필터(q/상위/사용), 신규/수정(메뉴코드RO)
- 그룹 권한: 목록/필터(그룹/메뉴/사용), 체크박스 매트릭스 편집 UI
7) 결재(UI)
- 결재(
/approvals): 목록/필터, 상세(개요/단계/이력 탭) - 템플릿 불러오기: 단계 탭에서 템플릿 선택 UI(단계 리스트 반영)
- 단계 행위: 승인/반려/코멘트 버튼(가능 여부 상태에 따라 비활성/툴팁)
- 단계 관리(
/approval-steps): 목록/편집(신규/수정) - 이력(
/approval-histories): 조회 전용 테이블 - 템플릿(
/approval-templates): 목록/헤더+단계 반복 폼
8) 우편번호 검색 모달(UI)
- 입력: 검색어 텍스트
- 결과 테이블: 우편번호/시도/시군구/도로명/건물번호
- 선택 시: 부모 폼
zipcode/주소 구성요소 채움
9) 보고서(/reports) UI
- 조건 폼: 기간/유형/창고/상태
- 액션: XLSX/PDF 버튼 — 미제공 시 버튼 비활성 UI(연동은 API 단계에서)
10) 데이터 계층/상태 관리
- 리포지토리 인터페이스(domain) 정의 및 구현(data): 트랜잭션/결재/마스터/룩업/우편번호
- DTO ↔ 도메인 엔티티 매핑(응답
{ items }/{ data }구조 표준화) - 페이지네이션 상태(현재 페이지/사이즈/전체) 및 필터 상태 싱크(go_router querystring 연동)
- 정렬/검색/Include 옵션 직렬화 및 유지
11) API 연동 단계(Dio/ApiClient/DI)
- 네트워킹 패키지 추가:
dio:^5.x,pretty_dio_logger(dev 선택), 토큰 저장용flutter_secure_storage(모바일)/웹 스토리지 ApiClient/AuthInterceptor스켈레톤 작성(설계:doc/API_CLIENT_SPEC.md)Environment.initialize()→get_itDI에서 ApiClient 생성/주입- 공통 에러 매핑(400/404/409/422) 및 토스트/필드 바인딩 연결
- 메뉴/권한 로딩 → 버튼/액션 노출 제어
- 각 화면 API 연결:
- 입고/출고/대여: 목록/상세/생성/수정/삭제/복구 + include/필터/정렬/페이지네이션
- 마스터: vendors/products/warehouses/customers/employees/menus/groups/group-permissions(+ 일괄 저장)
- 결재: approvals(+steps/histories), actions, can-proceed, 템플릿 CRUD/단계 배치
- 우편번호:
GET /zipcodes?... - 보고서: 다운로드 엔드포인트 연동(제공 시)
12) 검증/접근성/상호작용
- 필수/형식/업무 규칙 검증(출고/대여 고객 최소 1건 등)
- 키보드: Esc 닫기, Enter 제출/셀 이동, Tab 포커스 이동, 포커스 트랩
- 합계/요약 배지 실시간 반영(수량/단가 변경 시)
13) 반응형/열 가시성
- 데스크톱/태블릿/모바일 프리셋 구현(PRD 섹션 12 규칙 적용)
- 모바일 카드형 요약(핵심 3~4필드) 구성
14) 테스트/품질
flutter analyze경고 0- 위젯 테스트: 테이블 렌더/필터/페이지네이션/모달 열기/검증 메시지
- 내비 통합 테스트(선택): 로그인 → 대시보드 → 입/출/대여 → 결재 → 마스터
dart format .적용
15) Definition of Done(DoD)
- 모든 목록/폼/모달/필터/페이지네이션 동작
- 모바일/태블릿/데스크톱 레이아웃 검증(핵심 열 가시성)
- 실제 API로 주요 플로우(신규/수정/삭제/복구) 검증 완료
- 문서 최신화(PRD/체크리스트)
참고
- PRD:
doc/PRD_입출고_결재_v2.md - 사양:
doc/stock_approval_system_spec_v4.md,doc/stock_approval_system_api_v4.md - 네트워킹 설계:
doc/API_CLIENT_SPEC.md - 스타일 참조:
/Users/maximilian.j.sul/Documents/flutter/superport