심플하지만 꼼꼼하게 여행을 계획하고 기록할 수 있는 모바일 웹서비스입니다
React를 학습하고 진행한 첫 번째 토이 프로젝트로서, 아래 개념들을 활용하여 유용한 애플리케이션을 제작하기로 계획했습니다.
JSX
를 이용한컴포넌트
단위의 UI 구성React
에서 제공하는 다양한Hook
과 로직 재사용성을 위한Custom Hook
- 상태 관리를 위한
Context API
와Redux toolkit
SPA(Single Page Application)
구현을 위한react-router
Redux Middleware
를 활용한 비동기 작업 처리- type 안정성과 유지보수 용이를 위한
Typescript
redux-persist
를 활용한 상태데이터 캐싱 처리
2023.09.08 ~ 2023.12.03
➡️ trip-mate 바로가기 (모바일 환경에 최적화되어 있습니다)
📝 프로젝트 구상 기록
data:image/s3,"s3://crabby-images/fe3cf/fe3cfaeb9fe3db1f47474338ad1bc267a2823a5d" alt="image"
펼치기
📦 trip-mate
├─ src
│ ├─ App.tsx
│ ├─ assets
│ ├─ components
│ │ ├─ auth
│ │ ├─ branding
│ │ ├─ checklist
│ │ ├─ common
│ │ │ ├─ Button
│ │ │ ├─ DropdownMenu
│ │ │ ├─ FloatingAddButton
│ │ │ ├─ Form
│ │ │ ├─ IconButton
│ │ │ ├─ LargeTitle
│ │ │ ├─ LoadingSpinner
│ │ │ ├─ MapInput
│ │ │ ├─ Modal
│ │ │ ├─ NavBar
│ │ │ ├─ NavBarWithIcons
│ │ │ ├─ Overlay
│ │ │ ├─ Spacing
│ │ │ ├─ TabMenu
│ │ │ └─ TabSelector
│ │ ├─ expenses
│ │ ├─ forms
│ │ │ ├─ expense
│ │ │ ├─ profile
│ │ │ ├─ schedule
│ │ │ └─ trip
│ │ ├─ home
│ │ ├─ modal-contents
│ │ ├─ place-overview
│ │ └─ schedule
│ ├─ constants
│ │ └─ constants.ts
│ ├─ contexts
│ │ ├─ auth-context.tsx
│ │ ├─ form-context.tsx
│ │ ├─ loading-context.tsx
│ │ └─ modal-context.tsx
│ ├─ hooks
│ │ ├─ useApp.ts
│ │ ├─ useClickOutside.tsx
│ │ ├─ useForm.ts
│ │ ├─ usePlaceSelector.tsx
│ │ └─ useTabSelector.tsx
│ ├─ index.tsx
│ ├─ layouts
│ │ └─ bottom-nav
│ ├─ logo.svg
│ ├─ pages
│ │ ├─ ErrorPage.tsx
│ │ ├─ NotFoundPage.tsx
│ │ ├─ PrivateRoutes.tsx
│ │ ├─ RootPage.tsx
│ │ ├─ auth
│ │ ├─ branding
│ │ ├─ checklist
│ │ ├─ expenses
│ │ ├─ home
│ │ ├─ place-overview
│ │ ├─ profile
│ │ ├─ schedule
│ │ └─ trip
│ ├─ react-app-env.d.ts
│ ├─ service-worker.ts
│ ├─ serviceWorkerRegistration.ts
│ ├─ services
│ │ └─ firebase.tsx
│ ├─ store
│ │ ├─ checklistReducer.ts
│ │ ├─ expensesReducer.ts
│ │ ├─ index.ts
│ │ ├─ profileReducer.ts
│ │ ├─ scheduleReducer.ts
│ │ └─ triplistReducer.ts
│ ├─ styles
│ │ ├─ globalStyle.tsx
│ │ └─ page-wrap-padding-15.tsx
│ └─ utils
│ ├─ auth
│ ├─ checklist
│ ├─ common.ts
│ ├─ expenses
│ ├─ profile
│ ├─ schedule
│ └─ trip
└─ tsconfig.json
©generated by Project Tree Generator
- Google 로그인
Firebase Auth API
Context API
- 브랜딩 페이지
useState
react-slick
- 프로필 추가 및 수정 기능
Redux toolkit
redux thunk
Cloud Firestore
- 여행일정 추가/수정/삭제 기능
Redux toolkit
redux thunk
Cloud Firestore
- 여행 스케줄 추가/수정/삭제 기능
KakaoMap API
Redux toolkit
redux thunk
Cloud Firestore
Custom Hook
- 여행장소 한눈에보기 기능
KakaoMap API
Redux toolkit
useEffect
- 체크리스트, 여행경비 관리 기능
KakaoMap API
Redux toolkit
redux thunk
Cloud Firestore
- 모바일 앱으로 설치하여 사용할 수 있도록
PWA
적용
Google 로그인 | 브랜딩 페이지 | 프로필 확인 및 수정 | 여행일정 생성 |
---|---|---|---|
![]() |
![]() |
![]() |
![]() |
스케줄 관리 | 여행장소 한눈에보기 | 체크리스트 | 여행경비 관리 |
---|---|---|---|
![]() |
![]() |
![]() |