This is an example project to demonstrate dependency injection and Swinject in MVVM (Model-View-ViewModel) architecture with ReactiveCocoa. This project is a simplified version of Swinject/SwinjectMVVMExample to exactly follow my blog posts (except updates of Xcode and frameworks).
- Download the source code or clone the repository.
- Run
carthage bootstrap --no-use-binaries --platform iOS
. - Get a free API key from Pixabay. It is displayed in the API documentation page after you log in there.
- Create a text file named
Pixabay.Config.swift
with the following content inExampleModel
folder in the project. The string"YOUR_API_KEY"
should be replaced with your own key.
Pixabay.Config.swift
extension Pixabay {
internal struct Config {
internal static let apiKey = "YOUR_API_KEY"
}
}
The following blog posts demonstrate step-by-step development of the project.
- Dependency Injection in MVVM Architecture with ReactiveCocoa Part 1: Introduction
- Dependency Injection in MVVM Architecture with ReactiveCocoa Part 2: Project Setup
- Dependency Injection in MVVM Architecture with ReactiveCocoa Part 3: Designing the Model
- Dependency Injection in MVVM Architecture with ReactiveCocoa Part 4: Implementing the View and ViewModel
- Dependency Injection in MVVM Architecture with ReactiveCocoa Part 5: Asynchronous Image Load
MIT license. See the LICENSE file for details.