카카오톡 쇼핑하기를 클론 코딩한 프로젝트입니다.
https://user-app.krampoline.com/kd699661bca8fa
Available until 2023.08.18.
Clone the project
git clone https://github.com/blackhblee/step2-FE-kakao-shop-public.git
Install dependencies
npm install
Start the server
npm run start
├─ /src
│ ├─ /api : api 호출을 위한 모듈
│ ├─ /assets : 이미지 파일을 담는 곳
│ ├─ /components : Atomic pattern으로 구성된 컴포넌트
│ │ ├─ /atoms
│ │ ├─ /molecules
│ │ ├─ /organisms
│ │ └─ /templates
│ ├─ /hooks : 커스텀 훅
│ ├─ /layouts : 레이아웃 컴포넌트
│ ├─ /pages : 페이지 컴포넌트
│ ├─ /store : redux store
│ │ └─ /slices : redux slice
│ ├─ /utils : 유틸리티 함수
│ ├─ App.js
│ ├─ index.js
│ └─ ...
과제 1 - 페이지 구성
1. 헤더 (Header)
- 핵심 기능
- 메인 페이지 (로고) 이동, 장바구니 페이지 이동, 로그인 / 로그아웃
- 상세 기능
- 메인 페이지, 상품 상세 정보 페이지, 장바구니 페이지, 주문 페이지에서 헤더 출력
메인 페이지 버튼
클릭 시 메인 페이지로 이동장바구니 버튼
클릭 시 장바구니 페이지로 이동- (현재 로그인이 되어있지 않을 때)
로그인 버튼
클릭 시 로그인 페이지로 이동- (현재 로그인이 되어있을 때)
로그아웃 버튼
클릭 시 로그아웃 (로그인 상태 종료)
- 인터페이스 요구사항
- 입력(1) :
메인 페이지 버튼
클릭- 출력(1) : 메인 페이지로 이동
- 입력(2) :
장바구니 버튼
클릭- 출력(2) : 장바구니 페이지로 이동
- 입력(3) :
로그인 버튼
클릭- 출력(3) : 로그인 페이지로 이동
- 입력(4) :
로그아웃 버튼
클릭- 출력(4) : 메인 페이지로 이동
2. 메인 캐러셀
- 핵심 기능
- 슬라이드 광고를 캐러셀로 출력
- 상세 기능
- 메인 페이지에서 캐러셀로 슬라이드 광고 출력
- 5초마다 이미지 변경
좌/우 버튼
클릭 시 이미지 변경
- 인터페이스 요구사항
- 입력 :
좌/우 버튼
클릭- 출력 : 이미지 변경
3. 전체 상품 조회
- 핵심 기능
- 전체 상품 조회 및 출력
- 상세 기능
- 메인 페이지에서 전체 상품 목록 조회
- 전체 상품 조회 API로 상품 목록을 가져옴
- 상품 이미지와 상품 이름, 가격을 사용자 화면에 출력
- 상품 카드 클릭 시 상품 상세 정보 페이지로 이동
- 인터페이스 요구사항
- 입력(1) : -
- 출력(1) : 전체 상품 출력
- 입력(2) : 상품 카드 클릭
- 출력(2) : 상품 상세 정보 페이지로 이동
4. 푸터 (Footer)
- 핵심 기능
- 메인 페이지 (로고) 이동, 카카오 정보, 저작권 정보 출력
- 상세 기능
- 메인 페이지, 상품 상세 정보 페이지, 장바구니 페이지, 주문 페이지에서 푸터 출력
메인 페이지 버튼
클릭 시 메인 페이지로 이동- 카카오 정보 및 저작권 정보 출력
- 인터페이스 요구사항
- 입력 :
메인 페이지 버튼
클릭- 출력 : 메인 페이지로 이동
5. 로그인 페이지
- 핵심 기능
- 회원 서비스를 이용하기 위한 로그인
- 상세 기능
- 이메일과 비밀번호를 입력 후
로그인 버튼
을 클릭할 때 HTTP Request에 담겨 서버로 요청
- 인터페이스 요구사항
- 입력 : 이메일과 비밀번호 입력,
로그인 버튼
클릭- 출력 : 메인 페이지로 이동
6. 회원가입 페이지
- 핵심 기능
- 서비스 이용을 위한 회원 가입
- 상세 기능
- 이름과 이메일, 비밀번호(및 비밀번호 확인)를 입력
- 이메일 유효성 검사 (정규식)
- 비밀번호 유효성 검사 (영문, 숫자, 특수문자 포함 및 8~16자, 비밀번호 확인과 동일)
- 인터페이스 요구사항
- 입력 : 이름과 이메일, 비밀번호, 비밀번호 확인 입력,
회원가입 버튼
클릭- 출력 : 로그인 페이지로 이동
7. 상품 상세 정보 조회
- 핵심 기능
- 선택한 상품의 상세 정보와 옵션 출력
- 상세 기능
- 전체 상품 목록에서 상품 카드 클릭 시 상품 상세 정보와 옵션 조회 API를 통해 상품 상세 정보와 옵션 불러오기
- 인터페이스 요구사항
- 입력 : 전체 상품 목록에서 특정한 상품 카드 클릭
- 출력 : 상품 상제 정보와 옵션 출력
8. 상품 옵션 선택
- 핵심 기능
- 상품 상세 정보 페이지에서 상품 옵션 선택
- 상세 기능
- 상품 옵션 선택 시 아래에 선택한 상품 옵션 리스트에 추가
- 중복 선택 불가하므로 이미 선택한 상품 옵션일 경우 토스트 메시지 출력
- 인터페이스 요구사항
- 입력(1) : 상품 옵션 리스트에서 옵션 클릭
- 출력(1) : 선택한 상품 옵션 리스트에 추가
- 입력(2) : 중복된 옵션 클릭
- 출력(2) :
이미 선택된 옵션입니다.
토스트 메시지 출력
9. 선택한 상품 리스트
- 핵심 기능
- 선택한 상품 옵션의 수량 조절 및 삭제
- 상세 기능
- 선택한 상품 옵션의 수령을 조절하고 삭제 가능
- 선택한 옵션과 수량에 따른 합계 금액 출력
- 인터페이스 요구사항
- 입력 : 선택한 상품 옵션 옆에
+/- 버튼
클릭- 출력 : 각 버튼에 따라 조절된 옵션 수량 변동, 합계 금액 출력
10. 장바구니 담기
- 핵심 기능
- 장바구니에 상품 담기
- 상세 기능
장바구니 버튼
을 클릭하면 상품 배열이 HTTP Request에 담겨 서버에 전달되어 장바구니에 담김
- 인터페이스 요구사항
- 입력 :
장바구니 버튼
클릭- 출력 :
장바구니에 상품이 담겼습니다.
토스트 메시지 출력
11. 장바구니 조회
- 핵심 기능
- 장바구니 페이지에서 장바구니에 담긴 상품 확인
- 상세 기능
- 장바구니에 담긴 상품 데이터 출력
- 인터페이스 요구사항
- 입력 : -
- 출력 : 장바구니에 담긴 상품 데이터 출력
12. 장바구니 리스트
- 핵심 기능
- 장바구니에 담긴 상품 옵션의 수량 조절 및 삭제
- 상세 기능
- 상품 옵션과 수량에 따른 합계 금액 출력
- 상품 옵션의 수령을 조절하고 삭제 가능
주문하기 버튼
을 클릭하면 주문 화면으로 이동
- 인터페이스 요구사항
- 입력(1) : 상품 옵션 옆에
+/- 버튼
클릭- 출력(1) : 각 버튼에 따라 조절된 옵션 수량 변동, 합계 금액 출력
- 입력(2) :
주문하기 버튼
클릭- 출력(2) : 주문 페이지로 이동
13. 주문
- 핵심 기능
- 결제 전 주문 상품 확인 및 결제 동의 과정
- 상세 기능
- 장바구니 페이지에서
주문하기 버튼
클릭되었을 때 장바구니에 담긴 상품 배열이 HTTP Request에 담겨 서버의 장바구니 리스트 수정- 반환된 장바구니 리스트를 이용해 장바구니에 담긴 상품들의 정보와 수량, 합계 결제 금액 출력
구매조건 확인 및 결제 진행 동의
/개인정보 제3자 제공 동의
를 체크 박스로 입력 받아 체크 되었을 때만 결제 진행
- 인터페이스 요구사항
- 입력 :
구매조건 확인 및 결제 진행 동의
/개인정보 제3자 제공 동의
체크 박스- 출력 : -
14. 결제
- 핵심 기능
- 실제 결제하는 절차 없이 상품 주문
- 상세 기능
- 주문 페이지에서
결제하기 버튼
클릭 시 실제 결제하는 절차 없이 상품 주문한 것으로 처리
- 인터페이스 요구사항
- 입력 :
결제하기 버튼
클릭- 출력 : 구매 완료 페이지로 이동
15. 구매 완료 페이지
- 핵심 기능
- 결제 후 주문한 상품에 대한 결과 출력
- 상세 기능
- 주문 정보(상품명, 옵션, 결제 금액) 출력
쇼핑 계속하기 버튼
클릭 시 메인 페이지로 이동
- 인터페이스 요구사항
- 입력(1) : -
- 출력(1) : 주문 정보 출력
- 입력(2) :
쇼핑 계속하기 버튼
클릭- 출력(2) : 메인 페이지로 이동
과제 1 - 디렉터리 구조
/kakaotechcampus-kakaostore-clone
├─ /public : 컴파일이 필요 없는 정적 파일을 담는 곳
├─ /src
│ ├─ /components : 여러 페이지에서 사용되는 컴포넌트
│ │ ├─ Footer.js
│ │ ├─ Header.js
│ │ └─ ...
│ ├─ /dto : 데이터 검증을 위한 dto
│ ├─ /hooks : 커스텀 훅
│ ├─ /pages : 특정 페이지에서 사용되는 컴포넌트
│ │ ├─ Cart.js
│ │ ├─ Login.js
│ │ ├─ Main.js
│ │ └─ ...
│ ├─ /styles : css 파일을 담는 곳
│ ├─ api.js : api 호출 모듈
│ ├─ App.js
│ ├─ index.js
│ └─ ...
Step-2.-Week-1
1. 쇼핑몰 웹사이트 탐색을 통한 페이지 구성
2. UI 컴포넌트의 명칭과 사용법 익히기
✅과제 1.
쇼핑몰 웹사이트를 탐색해 어떠한 페이지 구성을 가지고 있는지 체크합니다.
대부분의 쇼핑몰은 다음의 페이지 구성을 가지고 있습니다.
- 메인 페이지
- 상품 검색 결과 페이지
- 개별 상품 상세 페이지
- 주문 목록 페이지
- 결제 페이지
- 결제 완료 페이지
- 장바구니 페이지
- ...
이와 같이 위의 서비스가 동작하는데 필수적인 페이지가 무엇이 있고, 해당 페이지에서 어떠한 기능이 구현되어야 하는지 작성하세요.
그리고 어떠한 디렉터리 구조로 프로젝트를 진행할지 작성해주세요. (README.md 파일에 작성)
README.md의 예시 형식입니다. 아래를 참고해 작성해주세요.
각 페이지마다 핵심 기능, 기능 상세 설명, 인터페이스 요구사항이 어떤 것이 있을지 고민해서 작성해주세요.
###예시
#페이지별 구성
1. 로그인 페이지
- 핵심 기능: 로그인 요청 및 사용자 로그인 정보 저장
- 기능 상세 설명: 이메일과 비밀번호를 이용해 로그인을 진행하고, 이에 대한 상태 처리를 합니다.
- 인터페이스 요구사항: 이메일 또는 비밀번호에 들어온 값이 적합하지 않은 경우 적절한 알림을 보냅니다.
-- ...
#디렉터리 구조
- public
- src
- components
- hooks
- routes
- styles
- dto
- ...
✅과제 2.
프론트 개발자가 다른 프론트 개발자와 소통 및 UI 디자이너와 소통하는데 필수적인 UI 컴포넌트의 명칭과 사용법을 익힙니다.
수업시간에 배운 컴포넌트의 명칭과 사용법 이외에 대표적인 UI 라이브러리 홈페이지를 조사해보면 수많은 컴포넌트가 어떤식으로 동작하는지 확인할 수 있습니다.
리액트 프로젝트를 생성하고, 토스트, 브래드크럼, 캐러셀, 라디오버튼, 토글버튼, 체크리스트를 UI 라이브러리가 아닌 자신만의 방식으로 스타일링하고 상태 관리를 적용해 코드를 작성하세요.
작성된 코드는 레퍼지토리에 업로드하여 멘토님에게 전달해주세요.
✅과제 3.
각 컴포넌트를 시현해 볼 수 있는 페이지를 만드세요.
하나의 페이지에 모든 컴포넌트를 둬도 좋고, 각 페이지별로 분리해도 괜찮습니다.
1. README.md 파일은 동료 개발자에게 프로젝트에 쉽게 랜딩하도록 돕는 중요한 소통 수단입니다.
해당 프로젝트에 대해 아무런 지식이 없는 동료들에게 설명하는 것처럼 쉽고, 간결하게 작성해주세요.
2. 좋은 개발자는 디자이너, 기획자, 마케터 등 여러 포지션에 있는 분들과 소통을 잘합니다.
UI 컴포넌트의 명칭과 이를 구현하는 능력은 필수적인 커뮤니케이션 스킬이자 필요사항이니 어떤 상황에서 해당 컴포넌트를 사용하면 좋을지 고민하며 코드를 작성해보세요.
1. PR 제목과 내용을 아래와 같이 작성 해주세요.
- PR 제목 : 부산대FE_라이언_1주차 과제
Step-2.-Week-2
1. 코드 디자인 패턴과 상태 관리
✅과제 1. 아토믹 컴포넌트 디자인 패턴 사용
- 회원가입, 로그인 페이지 개발에 필요한 컴포넌트를 아토믹 디자인 패턴을 사용해 작성하세요.
- 작성한 컴포넌트는 사용의 편의성을 위해 Props에 적절한 주석을 달아주세요.
✅과제 2. 회원 가입, 로그인 페이지 개발
- 백엔드 API 문서를 참고하여 회원가입, 로그인 페이지를 개발하세요.
- 각 페이지에는 적합한 값이 입력되도록 하고, 적절하지 않은 값이 들어온 경우 API 요청을 보내기 전에 프론트에서 에러 캐칭을 해주세요.
- 회원가입, 로그인 후에는 메인 페이지로 리다이렉트하세요.
- API 응답 과정에서 로그인이 실패하는 경우, 회원가입이 실패한 경우에 대해서 에러 캐칭도 적용해야 합니다.
✅과제 3. 상태관리 모듈 적용
- 로그인 후에 사용자의 정보를 상태관리 모듈을 하나 선정해 저장하고 불러올 수 있도록 코드를 작성하세요.
- 사용자가 로그인 상태일 때는 GNB 영역에 로그인 버튼이 보이면 안됩니다.
- 로그아웃시 상태를 초기화하세요.
- 새로고침 시에도 상태를 잃지 않고 유지해야 합니다.
- 일정한 시간이 지나면 로그인 유지가 끝나도록 설정하세요.(예: 1일)
1. 아토믹 컴포넌트를 작성할 때 Atoms, Molecules에 반드시 특정한 컴포넌트가 들어갈 필요는 없습니다. 개발자의 주관이 들어갈 수 있는 부분이니 적절한 뎁스로 나누어보세요.
2. API 요청을 보내고, 응답 받을 때 성공 케이스만 생각해 코드를 작성하는 경우가 많습니다. 숨은 에러 케이스는 없을지 한 번 더 고민해보세요.
3. 상태 관리 모듈은 자신이 써보고 싶은 어떤 모듈이던 상관 없습니다. 모듈을 사용해보면서 모듈에 들어가는 미들웨어나 툴도 사용해보세요.
1. PR 제목과 내용을 아래와 같이 작성 해주세요.
- PR 제목 : 부산대FE_라이언_2주차 과제
2. PR 내용 :
- 코드 작성하면서 어려웠던 점
- 코드 리뷰 시, 멘토님이 중점적으로 리뷰해줬으면 하는 부분
Step-2.-Week-3
1. 비동기 통신 활용과 레이아웃
✅과제 1. 상품 목록 페이지 개발
- 백엔드 API 문서를 참고하여 상품 목록 페이지를 개발하세요.
- 페이지네이션을 이용해 페이지 값을 증가시켜가며 조회될 수 있도록 코드를 작성해주세요.
- 데이터 로딩 과정에 로더를 구현하세요.
- 데이터 불러오기를 할 때 react-query를 사용해보세요.
✅과제 2. 스켈레톤과 로더
- 컴포넌트에 props를 전달해 데이터 로딩 중 스켈레톤 또는 로더가 적용될 수 있도록 코드를 작성해보세요.
- 상품 목록 카드에 스켈레톤을 적용하세요.
- 페이지 전체에 대한 로딩이 진행될 때는 글로벌 로더를 적용해보세요.(적절한 모듈을 찾아 적용해도 좋습니다.)
✅과제 3. 백엔드 상태 코드 반응
- API 응답에 대해 전처리 하는 코드를 작성해보세요.
- 200, 300, 400, 500번 대의 상태 코드별 에러 캐칭이 필요한 경우라면 해당 함수에서 먼저 실행되도록 코드를 작성합니다.
- react-query에서 전처리하는 방식이 있다면 해당 방식을 적용하거나 또는 별도의 함수나 클래스를 만들어 관리를 시도해보면 됩니다.
1. 스켈레톤과 로더를 바텀부터 만들기보단 Codepen 등을 참고해 구현하고, Props를 통한 실제 적용에 집중해주세요.
2. 과제 3번을 해결할 때 Facade pattern을 참고해보세요.
3. 과제 1번을 해결할 때 react-query를 사용해보되 전체 프로젝트에 react-query를 적용할 필요는 없습니다. 하나 이상의 API 요청에 적용해보세요.
1. PR 제목과 내용을 아래와 같이 작성 해주세요.
- PR 제목 : 부산대FE_라이언_3주차 과제
2. PR 내용 :
- 코드 작성하면서 어려웠던 점
- 코드 리뷰 시, 멘토님이 중점적으로 리뷰해줬으면 하는 부분
Step-2.-Week-4
상세 페이지 개발과 라이브러리
✅과제 1. 상품 상세 페이지 개발
- 백엔드 API 문서를 참고하여 상품 상세 페이지를 개발하세요.
- 한 개의 UI 라이브러리를 선정해 사용해보세요.
- 적절하지 않은 상품 ID 값이 들어오거나 찾을 수 없는 상품일 때 404 페이지 또는 "상품을 찾을 수 없습니다."라는 메시지가 있는 페이지로 이동될 수 있도록 코드를 작성하세요.
- 데이터 로딩이 완료될 때까지 로더를 적용하세요.
- '장바구니 담기' 버튼과 '구매' 버튼을 나누어 배치하세요.
✅과제 2. 장바구니 페이지 개발
- 백엔드 API 문서를 참고하여 장바구니 페이지를 개발하세요.
- 담아둔 상품에 대해 조회, 수량 변경, 항목 삭제가 구현되어야 합니다.
- '결제하기' 버튼을 만들고, 클릭시 결제 페이지로 이동될 수 있도록 개발하세요.
- 다른 모든 페이지와 마찬가지로 비동기 데이터 요청이 발생하니 로더 또는 스켈레톤을 통해 장바구니 목록을 불러올 때 로딩 상태를 표시하세요.
1. UI 라이브러리를 사용할 때 모든 구성요소에 UI 라이브러리의 규칙을 적용할 필요는 없습니다. UI 라이브러리의 사용법을 익히고, 하나 이상의 컴포넌트에 적용해봅니다.
1. PR 제목과 내용을 아래와 같이 작성 해주세요.
- PR 제목 : 부산대FE_라이언_4주차 과제
2. PR 내용 :
- 코드 작성하면서 어려웠던 점
- 코드 리뷰 시, 멘토님이 중점적으로 리뷰해줬으면 하는 부분
Step-2.-Week-5
주문 결제 개발
✅과제 1. 주문 결제 페이지 개발
- 백엔드 API 문서를 참고하여 주문 결제 페이지를 개발하세요.
- 결제 페이지에서는 결제 전 결제 상세 정보에 대한 데이터를 조회하고, 결제를 확정하는 기능 2가지에 중점을 둡니다.
✅과제 2. 테스트 결제
- 한 개의 PG 서비스 또는 PG 서비스를 돕는 서드파티 앱을 사용해 개발합니다.
- 테스트 환경에서 결제를 성공해야 합니다.
- 결제가 실패하는 경우(잔고 부족, 결제 정보 불일치 등)에 대해 에러 캐칭을 적용하세요.
- 다양한 에러 상황에 대해 주석으로 에러 상황과 대응 방식을 설명해주세요.
1. 결제를 구현할 때 새로운 모듈을 학습하는데 있어서 생각보다 시간 소요가 클 것입니다. 또한 몇몇의 PG사에서 제공하는 SDK의 경우 리액트와 호환성이 나쁜 경우도 있습니다.
2. 테스트 결제시에 실제 비용이 나가는 것처럼 보이는 경우도 있습니다. PG사마다 정책이 다르지만 대부분 테스트 금액은 1일 이내로 환급받는 구조입니다.
3. 결제시에는 생각보다 많은 데이터를 하나의 페이로드에 담아 전달해야 합니다. 이 과정에서 데이터가 적절하지 않은 값이 들어갈 가능성이 높고, 코드가 복잡해질 수 있습니다. 기능 단위를 나누어 함수형 프로그래밍을 시도해보는게 도움이 될 수 있습니다.
1. PR 제목과 내용을 아래와 같이 작성 해주세요.
- PR 제목 : 부산대FE_라이언_5주차 과제
2. PR 내용 :
- 코드 작성하면서 어려웠던 점
- 코드 리뷰 시, 멘토님이 중점적으로 리뷰해줬으면 하는 부분
Step-2.-Week-6
프로젝트 마무리
✅과제 1. 배포
- 카카오 배포환경을 통해 배포를 진행합니다.
- 계정을 생성하고 자신의 레포지토리를 연결해 배포합니다.
- 배포 레벨에서 사용될 환경 변수는 �인스턴스에 적용되도록 직접 설정해줍니다.
- 배포에 사용될 브랜치는 개발 브랜치와 꼭 분리합니다.
✅과제 2. 프로젝트 마무리
- 모든 핵심 기능이 정상 작동되도록 숨은 버그와 기능을 점검합니다.
- 특정한 파일이 너무 크다면, 코드 내의 함수를 다른 파일로 옮겨 import / export 하는 등 코드 리펙터링을 진행합니다.
- 개발 환경과 배포 환경 모두 버그가 없는지 체크합니다.
✅과제 3. README.md 정리
- 배포한 환경에 대해 구체적인 설명을 남겨주세요.
- 포함될 내용은 배포 순서, 배포에 영향 받는 브랜치, 배포시 주의 사항, 배포 환경 등 다른 개발자가 해당 프로젝트를 인수인계 받았을 때 문제가 없도록 꼼꼼히 작성합니다.
1. 많은 서비스가 개발 레벨에서는 잘 작동하다가도 배포 단계에서 에러를 만나는 경우가 많습니다. 배포 후에 기능을 하나하나 점검해보고, 여러 환경에서 시도해보세요.
2. 배포된 환경을 하나의 브라우저에서만 테스트하지 말고, 최대한 다양한 디바이스와 브라우저에서 테스트해보세요. 삼성 브라우저, 아이폰 사파리, 데스크탑이라면 크롬, 사파리, 파이어폭스 등으로 테스트해보세요.
3. 코드를 시간이 지나서 보면 어떤 목적으로, 왜 만들었는지 알아보기 힘든 경우가 많습니다. 기본적인 내용이라 생각한 부분도 주석을 달아주세요.
1. PR 제목과 내용을 아래와 같이 작성 해주세요.
- PR 제목 : 부산대FE_라이언_6주차 과제
2. PR 내용 :
- 코드 작성하면서 어려웠던 점
- 코드 리뷰 시, 멘토님이 중점적으로 리뷰해줬으면 하는 부분