Skip to content

COW-MJU-Craft/COW-MJCRAFT-FE

Repository files navigation

MJU-CRAFT-FE

명지대학교 중앙동아리 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 파일을 생성하고 값을 설정했습니다.

  • 개발 서버에서 /apivite.config.ts의 프록시 설정을 따릅니다.
  • 배포 환경에서는 vercel.json 리라이트 규칙을 사용합니다.

스크립트

npm run dev      # 개발 서버 실행
npm run build    # 타입 체크 + 프로덕션 빌드
npm run preview  # 빌드 결과 미리보기
npm run lint     # ESLint 실행

라우팅 개요

  • 사용자 영역: SiteLayout
  • 관리자 영역: AdminLayout
  • 로그인/소셜 콜백 페이지 포함

자세한 라우트는 src/App.tsx를 참고하세요.

API 통신

  • src/api/client.ts의 Fetch 기반 클라이언트 사용
  • 토큰은 localStorageVITE_TOKEN_KEY로 관리
  • 필요 시 Authorization: Bearer <token> 자동 부착

인증/소셜 로그인

  • 카카오/네이버 OAuth 콜백 라우트 사용
  • 관련 API 모듈: src/api/oauth.ts

UI 공통 요소

  • 전역 토스트: 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/fontssrc/styles/font.css에 정의되어 있습니다.

About

COW X 명지공방

Resources

Stars

Watchers

Forks

Releases

No releases published

Contributors

Languages