Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/powerwolf543/Swift-MVP-Sample
It's an iOS simple project that how I implement MVP (Model-View-Presenter) and Clean Architecture in Swift.
https://github.com/powerwolf543/Swift-MVP-Sample
clean-architecture ios mvp repository-pattern swift viper-architecture
Last synced: about 2 months ago
JSON representation
It's an iOS simple project that how I implement MVP (Model-View-Presenter) and Clean Architecture in Swift.
- Host: GitHub
- URL: https://github.com/powerwolf543/Swift-MVP-Sample
- Owner: powerwolf543
- License: mit
- Created: 2018-11-11T09:39:25.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2020-08-22T11:35:16.000Z (over 4 years ago)
- Last Synced: 2024-11-18T01:03:35.791Z (about 2 months ago)
- Topics: clean-architecture, ios, mvp, repository-pattern, swift, viper-architecture
- Language: Swift
- Homepage:
- Size: 15.1 MB
- Stars: 41
- Watchers: 3
- Forks: 6
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome - Swift-MVP-Sample - It's an iOS simple project that how I implement MVP (Model-View-Presenter) and Clean Architecture in Swift. (OOM-Leaks-Crash / Architecture Design Pattern)
README
[![swift](https://img.shields.io/badge/language-swift-red.svg)](https://developer.apple.com/swift/)
# Swift-MVP-Sample
It's an iOS simple project that how I implement `MVP` (Model-View-Presenter) and `Clean Architecture` in Swift.
## Requirements
- Xcode 10.2+
- Swift 5.0+## Architecture
![](architecture.jpg)
### View Layer (MVP)
- `View` - Displays information from the `Presenter` and sends user interactions back to the `Presenter`.
- `Presenter` - Contains the presentation logic and tells the `View` what to present
- `ViewBuilder` - The `Builder’s` responsibility is to instantiate a specific `View` and injects the dependency for all components.
- `Router` - Handles navigation logic for which screen should appear and when.### Domain Layer
- `UseCase` - Contains the business logic for a specific use case in the project. They are view agnostic and can be consumed by one or many `Presenters`.
- `Model` - Simple data model objects.### Data Layer
- `Repository` - Query objects from different data sources (Core Data, Realm, web server, etc.) with a only single-entry point.## References
- [iOS: MVP clean architecture in Tiendeo app](https://medium.com/tiendeo-tech/ios-mvp-clean-architecture-in-tiendeo-app-a8a597c49bb9)
- [Library - iOS - MVP + Clean Architecture Demo](https://github.com/FortechRomania/ios-mvp-clean-architecture/)
- [The Clean Architecture, by Uncle Bob](https://blog.cleancoder.com/uncle-bob/2012/08/13/the-clean-architecture.html)
- [Test Double](https://www.martinfowler.com/bliki/TestDouble.html)## Author
Nixon Shih, [email protected]
## License
Swift-MVP-Sample is available under the MIT license. See the LICENSE file for more info.