Skip to content

세차용품 안전정보 제공 및 검증 된 세차 관련 정보를 보여주는 플랫폼

License

Notifications You must be signed in to change notification settings

eun-hak/F1-WashFit-FE

 
 

Repository files navigation

🚗 안전한 세차용품 정보 제공 플랫폼

🔗 프로젝트 링크


📖 프로젝트 소개

  • Washpedia는 차를 깨끗하게 만드는 "세차 용품"에 대한 기본 정보와 유해성 유무를 쉽게 찾아볼 수 있는 웹 서비스입니다.
  • 사용자 정보를 바탕으로 세차용품을 추천 받을 수 있습니다.
  • 주변에 세차장이 어디 있는지, 어떤 후기가 담겨있는지 확인할 수 있습니다.
  • 세차 관련 유튜브 영상을 추천 받을 수 있어요.

🕹️ 기술적 성취

  • 백엔드 팀과 비동기적 소통 및 협업 경험
  • 기획부터 디자인까지 참여한 경험
  • ci/cd 배포,빌드,테스트 자동화 파이프 라인 구축
  • storybook을 이용한 시각적 회귀 테스트 및 vitest, msw를 이용한 테스트 코드 작성

🎯 팀 소개

임병욱 백서영 조기범

@bottlewook

@seoye0ng
Example Image
@eun-hak

⚒️ 기술 스택

프로그래밍 언어
TypeScript

프레임워크
NextJS

스타일
Sass

전역 상태 관리
ReduxToolkit

테스팅
Vitest Storybook MockServiceWorker Testing Library

협업 툴
GitHub Notion Slack Figma

버전 관리
Git

API
Axios

라이브러리
TanstackQuery React Hook Form Swiper

배포
Vercel Chromatic

그 외
Eslint


👍 성능 최적화

  • 웹 폰트 다운로드 시간을 줄이기 위해 woff2 확장자 추가 및 3초 이상 폰트가 다운로드 되지 못한 경우, 기존 폰트를 사용하도록 fallback 설정
  • 필요한 시점에 이미지를 불러오도록 lazy loading을 적용 및 layout shift를 방지하기 위한 Next.js image 태그 적용
  • 렌더링 시 불필요한 연산을 줄이기 위해 useCallback, useMemo 사용
  • dynamic import를 사용하여 빌드 타임이 아닌 런타임에서 컴포넌트를 랜더링 하도록 코드 스플리팅 적용
  • react-hook-form을 사용하여 불필요한 리랜더링 방지 및 마운팅 속도 증가
  • 불필요한 api 요청을 방지하기 위해 tanstack-query를 활용한 데이터 캐싱

✈️ 진행 사항

  • 초기 환경 설정

    • 린트 및 스타일 린트 설정
    • tanstack-query 보일러 플레이트 제작
    • redux-toolkit 보일러 플레이트 제작
    • storybook 보일러 플레이트 제작
    • vitest 보일러 플레이트 제작
    • msw 보일러 플레이트 제작
    • pretandard 폰트 설정
    • 컬러 팔레트 제작
    • ci / cd workflow 작성
    • vercel 배포
  • 20개 공통 컴포넌트 제작

  • 페이지 <- 모바일 환경에서 봐주세요!

🖐️ 질문 사항

  1. 스토리북을 사용하고 있지만 단순히 props만 바꿔가며 변경된 UI만 볼 수 있도록 테스팅을 하고 있는데 현업에선 어떤 식으로 스토리북을 사용하나요?
  2. next.js에서 private router 구현하려면 HOC를 이용하여 컴포넌트를 감싸 유저가 가진 token을 이용하여 유효한 회원인지 판단하는 로직 일반적인가요? 그게 아니라면 어떤 식으로 구현하는 게 좋을까요?
  3. swiper.js를 사용하여 캐러셀을 제작했는데 초기 랜더링 시 layout shift가 발생하는 문제점이 있어요. 이 문제점을 해결할 수 있는 좋은 방법이 있을까요?

About

세차용품 안전정보 제공 및 검증 된 세차 관련 정보를 보여주는 플랫폼

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 85.8%
  • SCSS 6.0%
  • MDX 3.7%
  • JavaScript 2.5%
  • CSS 1.5%
  • Dockerfile 0.5%