Skip to content

derrickkim0109/DawnMarket

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Dawn Market

프로젝트 기간 2023.11.17 ~ 2023.12.01 (14일)
기능 구현 기간 2023.11.18 ~ 2023.11.26 (8일)

개발자 : iOS 개발자 김태현

📋 목차

🔎 프로젝트 소개

DawnMarket 앱을 클론 코딩한 프로젝트입니다.

📺 프로젝트 실행화면

카테고리 탭화면 나머지 탭화면 카테고리 View 미개발된 기능
Pagination 카테고리 하위목록 및 SearchValue 선택
LaunchScreen 상품명 토글 카테고리 대분류 조회 실패
퀵 메뉴 조회 실패 카테고리 하위목록 조회 실패 카테고리 상품목록 조회 실패

🗂 App 구조

기술스택

  • SwiftUI
  • Combine
  • CleanArchitecture + MVVM
  • Unit Test

외부 라이브러리

Version

  • Xcode 15.0.1
  • iOS Simulator 17.0.1
  • iOS Deployment Target 15.0
  • Minimum Deployment 15.0

Commit Convention

  • Karma

🗺️ DI Container

Clean Architecture로 분리한 Layer들을 ViewModel까지 주입하여 RootView에서 생성하기 위한 여러 고민들이 있었습니다. 그 중 가장 중요하게 생각한 부분은 Category 대분류 List가 나오는 View에서 Detail로 화면 전환이 일어날 때입니다. UIKit에서는 Coordinator 패턴을 사용하여 화면 전환을 할 때, 각 Coordinator를 주입해주면 되었습니다. 하지만 SwiftUI는 View 위에 View가 그려지는 방식으로 어떻게 Coordinator와 유사한 객체를 만들어서 DI Container를 효율적으로 만들 수 있을 지에 대해 고민하였습니다.

Flow Router

참고 Repository - Flow Router - iOS 16이상

SwiftUI에서는 Flow Router 객체를 만들어 사용하면 AView의 ViewModel과 ADetailView의 ViewModel을 주입할 수 있습니다.

⁇ 고민한 점

MVVM, Clean Architecture

  • 클린 아키텍처의 핵심 개념인 의존성 역전 원칙과 인터페이스를 활용하여 각 레이어를 분리하고, 각 레이어 사이의 의존성을 최소화했습니다. MVVM은 뷰, 뷰 모델, 모델로 구성되어 있으며, 각 역할에 따라 책임을 명확하게 분리했습니다. 이러한 클린 아키텍처와 MVVM의 조합을 통해 프로젝트는 유지 보수성과 확장성을 높이며, 테스트 용이성을 제공합니다. 또한, 코드의 가독성과 재사용성을 향상시키고, 애플리케이션의 비즈니스 로직과 UI를 분리하여 개발 과정을 단순화했습니다.

Dependency Direction

Layers

Domain Layer = Entities + Use Cases + Repositories Interfaces
Data Repositories Layer = Repositories Implementations + API (Network)
Presentation Layer (MVVM) = ViewModels + Views + Model

  • Domain Layer에 다른 레이어(예: Presentation — UIKit, Data Layer — Mapping Codable)가 포함되지 않도록 처리했습니다.
  • Presentation Layer에 Domain Entity를 맵핑하기 위한 Mapper 타입, Model 타입을 구현하여 Domain인과의 의존성을 최소화 시켰습니다.

📋 일정관리

스크린샷 2023-11-11 13 14 44

GitHub issue 이미지

  • 구현할 feature, test에 대한 내용을 Github의 issues에 정리했습니다. 진행할 업무를 정리하고, 우선순위를 정하기 위함입니다.
  • 진행하는 issue들 별로 Todo, In Progress, Done을 통해 Feature History를 관리했습니다.

스크린샷 2023-11-11 13 15 03

GitHub branch 이미지

  • Branch를 issue별로 분기 처리하여 관리하였습니다.

Git Flow

각 Branch의 구현 후, develop 브랜치에 Merge하고 최종적으로 main Branch에 Merge하는 방식으로 과제를 수행하였습니다.

About

SwiftUI, Combine, UnitTest, CleanArchitecture + MVVM, Moya, Kingfisher

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages