Skip to content

Latest commit

 

History

History
134 lines (111 loc) · 4.53 KB

README.md

File metadata and controls

134 lines (111 loc) · 4.53 KB

쿠팡로고


Coupang-frontend

31기 IN SOPT 합동세미나 3조


개발자 소개 및 역할 분배


최유진 김형겸 박현지
@Yujin Choi @Hyeongkyeom Kim @HyeonJi Park
장바구니 뷰
카테고리 뷰 및 api
footer
홈 뷰
BEST api
Navbar
header
TODAY'S HOT api

협업 방식


1. ⌨️ Code Convention

토글 버튼을 클릭하면 확인할 수 있습니다.
  • ESLint, prettier 사용
  • 폴더명은 소문자로 시작
  • Event handler 이름 : on으로 시작, 복잡한 네이밍의 경우 handle~
  • 배열과 관련된 변수명은 __List (ex. reservationList)
  • 변수, 함수 : Camel case 사용
  • container와 wrapper 구분해서 사용하기 container: 여러 개의 요소를 감싸는 div. wrapper: 단일 요소의 레이아웃을 위한 div.
  • 함수
    • 함수명은 동사로 시작
    • const 함수명 = () => {} 형식으로 작성
  • 컴포넌트
    • 컴포넌트를 정의한 파일 : Pascal case 사용
    • function 컴포넌트명() {} 형식으로 작성
  • styled-components
    • 코드 하단에 작성
    • px 대신 rem 사용 (ex. 10px = 1rem)
    • 항상 맨 앞에 St 붙여주기
    • 최상단 태그 이름은 St[컴포넌트명]
      function Home() {
        return <StHome>...</StHome>;
      }
    • 색상은 항상 아래처럼 ThemeProvider 활용해서 설정
      button {
        background-color: ${(props) => props.theme.colors.blue01};
        color: ${(props) => props.theme.colors.gray700};
      }
  • API 호출 함수 : api.ts에 작성하기
  • 피그마에서 svg를 export해서 src/assets/icons 혹은 src/assets/images에 저장하고, src/assets/index.js에 아래처럼 추가해 사용
    export { default as icSample } from './icons/ic_sample.svg';
    export { default as imgSample } from './images/img_sample.svg';

2. commit message

- init: 개발 환경 초기 세팅
- feat: 새로운 기능 추가
- design: UI를 위한 스타일링
- fix: 버그 수정
- docs: 문서 추가, 수정, 삭제
- style: 코드 포맷팅(코드 순서 변경, 세미콜론 추가)
- refactor: 코드 리팩토링
- chore: 그 외 자잘한 수정

3. Git Branch Strategy

  • github flow
  • main - develop - feature
    • main : 배포
    • develop : 개발된 기능을 통합하는 브랜치
    • feat/[기능] : 기능별로 개발을 진행하는 브랜치
  • 브랜치명 : feat/페이지 지름-구현할 기능 (ex. 카페고리 페이지의 뷰 작업일 경우 category-ui, 홈 화면의 베스트 상품 작업일 경우 home-bestitem)
  • PR제목 : [브랜치명] 작업 내용 요약
  • 이슈 생성: [브랜치명] 작업 내용 요약
    • task 목록 작성
  • 팀원 2인의 리뷰 후에 approve 받아야 develop 브랜치에 merge 가능

4. 폴더 구조

├── mock-data 🗂 목 데이터 저장
├── package.json 📦 설치된 패키지를 관리하는 파일
├── public
│   └── assets
│   │   ├── icons 🗂 아이콘 저장
│   │   └── images 🗂 이미지 저장
└── src
    ├── App.tsx ✡️ 앱의 라우팅과 글로벌 스타일 지정
    ├── index.ts
    ├── component
    │   ├── common 🗂 공통으로 쓰일 컴포넌트 저장
    │   ├── home 🗂 home 페이지에 쓰일 컴포넌트 저장
    │   ├── category 🗂 category 페이지에 쓰일 컴포넌트 저장
    │   ├── cart 🗂 cart 페이지에 쓰일 컴포넌트 저장
    │   └── myPage 🗂 myPage 페이지에 쓰일 컴포넌트 저장
    ├── pages 🗂 라우팅 시 보여질 페이지 컴포넌트 저장
    │   ├── home
    │   ├── category
    │   ├── cart
    │   └── myPage
    ├── libs
    │   └── api.ts
    └── styles
        ├── GlobalStyle.tsx
        ├── styled.d.ts
        └── themep.ts