Files
sam-react-prod/sam-docs/frontend/v1/00-overview.md
유병철 c309ac479f feat: [vehicle] 법인차량 관리 모듈 + MES 분석 보고서 + 프론트엔드 문서
- 법인차량 관리 3개 페이지 (차량등록, 운행일지, 정비이력)
- MES 데이터 정합성 분석 보고서 v1/v2
- sam-docs 프론트엔드 기술문서 v1 (9개 챕터)
- claudedocs 가이드/테스트URL 업데이트
2026-03-13 17:52:57 +09:00

3.2 KiB

SAM ERP 프론트엔드 개발 가이드

대상: SAM ERP 프론트엔드 신규/기존 개발자 최종 업데이트: 2026-03-13


목차

문서 내용
00-overview.md 프로젝트 개요 및 기술 스택 (이 문서)
01-project-structure.md 디렉토리 구조 및 파일 배치 규칙
02-routing-and-pages.md 라우팅, 페이지 모드, 레이아웃
03-authentication.md 인증 흐름, HttpOnly 쿠키, API 프록시
04-server-actions.md Server Action 패턴, API 통신 유틸리티
05-common-components.md 공통 컴포넌트 (organisms, molecules, templates)
06-ui-components.md UI 컴포넌트 카탈로그
07-hooks.md 공통 Hooks
08-utilities.md 유틸리티 함수 (포맷터, URL 빌더, 인쇄 등)
09-coding-conventions.md 코딩 컨벤션 및 필수 규칙

프로젝트 개요

프로젝트: SAM ERP (통합 자원관리 시스템)
프론트엔드: Next.js 15 (App Router, TypeScript)
백엔드 API: PHP Laravel (sam-api)
특성: 인증 필수 폐쇄형 ERP (SEO 불필요, 크롤링 차단)

저장소 구조

sam_project/
├── sam-next/sma-next-project/sam-react-prod/  # Next.js 프론트엔드 (현재)
├── sam-api/sam-api/                            # PHP Laravel 백엔드 API
├── sam-design/sam-design/                      # React 디자인 시스템
└── sam-hotfix/sam-hotfix/                      # E2E 테스트/핫픽스 관리

기술 스택

카테고리 기술
프레임워크 Next.js 15 (App Router, Turbopack)
언어 TypeScript (strict)
스타일링 Tailwind CSS
UI 라이브러리 Radix UI (shadcn/ui 기반)
상태 관리 Zustand
폼 관리 react-hook-form + Zod (신규 폼)
차트 Recharts
국제화 next-intl (ko, en, ja)
토스트 Sonner
아이콘 Lucide React
날짜 date-fns (한국어 locale)
인증 HttpOnly Cookie + API Proxy
모바일 Capacitor (하이브리드 앱)

핵심 원칙

  1. 모든 페이지는 Client Component ('use client') - 폐쇄형 ERP이므로 SEO 불필요, 서버 컴포넌트에서 쿠키 갱신 불가
  2. HttpOnly 쿠키 인증 - JavaScript에서 토큰 접근 불가, API Proxy 필수
  3. mode 쿼리파라미터 - /new, /edit 별도 경로 대신 ?mode=new, ?mode=edit 사용
  4. buildApiUrl 필수 - URL 직접 조립 금지
  5. 컴포넌트 재사용 - 새 컴포넌트 전 기존 컴포넌트 검색 필수

개발 환경

# 로컬 개발 서버
npm run dev

# 타입 체크
npx tsc --noEmit

# 빌드 (로컬 확인용)
npm run build

브랜치 전략

브랜치 역할
develop 평소 작업 브랜치 (자유롭게 커밋)
stage QA/테스트 환경
main 배포용 (기능별 squash merge)
feature/* 큰 기능/실험적 작업