명지대학교 중앙동아리 COW 1팀에서 개발한 COW X MJU_CRAFT 프로젝트 프론트엔드 레포지토리입니다.
- React 19.2.0
- TypeScript 5.9.3
- Vite 7.2.4
- Tailwind CSS 4.1.18
- React Router DOM 7.11.0
- @dnd-kit (drag & drop)
- react-markdown + remark-gfm/remark-breaks
- lucide-react (icons)
- Fetch API 기반 커스텀 클라이언트 (
src/api/client.ts) - ESLint 9 (flat config, react-hooks/refresh 포함)
- Vercel 배포 (배포 및 리라이트 설정)
src/
├─ api/ # API 요청 모듈
├─ assets/ # 정적 자원 (로고, 폰트 등)
├─ components/ # 공용 컴포넌트
│ ├─ confirm/ # 전역 Confirm 모달
│ ├─ toast/ # 전역 Toast
│ └─ order/ # 주문 관련 컴포넌트
├─ constants/ # 상수 정의
├─ data/ # 정적 데이터
├─ features/ # 도메인별 기능
├─ hooks/ # 커스텀 훅
├─ pages/ # 라우트 단위 페이지
│ ├─ site/ # 사용자 영역
│ └─ admin/ # 관리자 영역
│ └─ sections/ # 관리자 하위 섹션
├─ styles/ # 전역 스타일
├─ types/ # 타입 정의
└─ utils/ # 유틸 함수
프로젝트 루트에 .env 파일을 생성하고 값을 설정했습니다.
- 개발 서버에서
/api는vite.config.ts의 프록시 설정을 따릅니다. - 배포 환경에서는
vercel.json리라이트 규칙을 사용합니다.
npm run dev # 개발 서버 실행
npm run build # 타입 체크 + 프로덕션 빌드
npm run preview # 빌드 결과 미리보기
npm run lint # ESLint 실행- 사용자 영역:
SiteLayout - 관리자 영역:
AdminLayout - 로그인/소셜 콜백 페이지 포함
자세한 라우트는 src/App.tsx를 참고하세요.
src/api/client.ts의 Fetch 기반 클라이언트 사용- 토큰은
localStorage의VITE_TOKEN_KEY로 관리 - 필요 시
Authorization: Bearer <token>자동 부착
- 카카오/네이버 OAuth 콜백 라우트 사용
- 관련 API 모듈:
src/api/oauth.ts
- 전역 토스트:
src/components/toast/ToastProvider - 전역 확인 모달:
src/components/confirm/ConfirmProvider
vercel.json의 rewrite로/api요청을 백엔드로 프록시- 정적 SPA 라우팅을 위해 모든 경로를
/로 리라이트
- ESLint Flat Config 사용 (
eslint.config.js) - TypeScript strict 모드 기반
- Vite + Tailwind 구성이며 전역 스타일은
src/index.css에서 관리합니다. - 폰트는
src/assets/fonts와src/styles/font.css에 정의되어 있습니다.