⚜ 박민주
- 15번 상품 정보 고시 기능 구현
- 항목, 정보고시 버튼 클릭 시 항목 생성,삭제
- 달력 라이브러리 (MUI)
- layout (Header, navBar 등) 과 1-2, 15-20 마크업
⚜ 윤예나
- 3번 카테고리 기능 구현
- 체크박스 클릭 시 우측에 태그 생성
- 태그 클릭 시 해당된 체크박스 해제
- 체크박스 클릭 시 우측의 태그 해제
- common 폴더의 공통 뷰 컴포넌트 작성 (Grid, Button, Input 등)
- 16~20번 토글 스위치 버튼 구현 (common 폴더의 Switch.js)
⚜ 안병진
- 상품 이미지 첨부 기능
- 프리뷰가 있는버전 이미지 프리뷰기능 , 제거 기능 구현
- 프리뷰가 없는버전 이미지이름 옆에 띄우는기능 ,제거 기능 구현
- 상품 옵션 추가
- 큰 옵션 추가/제거 기능 구현
- 작은 옵션 추가/제거 기능 구현
- 추가 옵션 추가/제거 기능 구현
- 상품 옵션 페이지에서 다음 버튼 클릭시 입력한 데이터를 전부 콘솔로그에 찍히게 했음
⚜ 이지용
- 4번. 필터 태그 기능
- input focus 시 모든 태그 View
- 검색 글자에 매칭되는 태그 View
- 선택된 태그 View
- 중복태그 추가 x
- 선택된 태그 삭제 기능
- 5번. 상품명, 상품 코드
- uuid를 이용한 고유한 상품 코드 생성
- 6번. 상품 구성 소개 정보
- 9번. 상품 총 재고
px로 컴포넌트 박스 구현 시 모니터 크기에 따라 박스 크기의 비율이 달라지는 현상을 발견하였습니다.
px 대신 rem 개념을 사용하여 최상위 root 태그의 font-size를 기준으로 모니터 크기에 따라 다른 px값이 적용되도록 하였습니다.
// App.css
#root {
font-size: 16px; // root에서 font-size를 지정하였습니다.
}
// 미디어 쿼리를 통해 서로 다른 모니터 크기에 따라 root의 font-size가 다르게 적용되도록 하였습니다.
@media screen and (max-width: 1500px) {
#root {
font-size: 18px;
}
}
@media screen and (max-width: 2550px) {
#root {
font-size: 20px;
}
}
// 예: width를 40rem이라고 하면 각 모니터에 적용된 font-size에 따라 width의 전체 px 값이 결정됨
설치
npm run build
시작
npm run start
.
├── App.jsx
├── assets
│ └── deleteIcon.png // x 버튼 이미지
├── common
│ ├── Button.js // Button styled 컴포넌트
│ ├── Checkbox.js // Checkbox styled 컴포넌트
│ ├── Grid.js // Grid styled 컴포넌트
│ ├── Input.js // Input styled 컴포넌트
│ ├── Switch.js // Switch styled 컴포넌트
│ ├── Text.js // Text styled 컴포넌트
│ └── index.js
├── components // 프로젝트 구성 컴포넌트
│ ├── Category.js
│ ├── FilterTag
│ │ ├── FilterTag.js
│ │ ├── SearchTag.js
│ │ └── SelectedTag.js
│ ├── Header.js
│ ├── ImageUpload.js
│ ├── Layout.js
│ ├── Navbar.js
│ ├── ProductImage.js
│ ├── ProductInfo.js
│ ├── ProductNoticeInfo
│ │ ├── NoticeInfo.js
│ │ ├── OfferThankCard.js
│ │ ├── ProductOptionToggle.js
│ │ ├── ProductShppingSetting.js
│ │ ├── SaveMileage.js
│ │ └── index.js
│ ├── ProductPeriod.js
│ ├── ProductRest.js
│ ├── Sidebar.js
│ ├── SubHeader.js
│ └── index.js
├── index.js
├── pages // 프로젝트 구성 페이지
│ ├── BasicInfo.js
│ ├── ProductImage.js
│ ├── ProductNoticeInfo.js
│ ├── ProductOption.js
│ ├── ProductsPeriodSetting.js
│ └── index.js
├── styles
│ ├── App.css // css 초기 설정
│ └── palette.js // 색 설정 값
└── utils
├── categoryData.js // category Data 자료
├── pickers
│ ├── DatePicker.js
│ └── DateRangePicker.js
└── tagData.js // filter tag Data 자료