Skip to content

Movies app written in Swift 5 using the TMDb API and demonstrating Clean Architecture, Dependency Injection, MVVM and Coordinators.

License

Notifications You must be signed in to change notification settings

DeluxeAlonso/UpcomingMovies

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Upcoming Movies App

License Platform Swift 5 codecov

Movies app written in Swift 5 using the TMDb API and demonstrating Clean Architecture, Dependency Injection, MVVM and Coordinators.

Demo

Screenshots

How to run

Requirements

  1. Xcode 14.0+
  2. Cocoapods 1.9.0+
  3. Fastlane 2.1.0+ (only needed if you want to run the unit tests and swift lint scans via the CLI).

Getting started

  1. Clone this repository.
  2. Via the CLI, go to the root folder of the project where Podfile is located and run pod install.
  3. Open the workspace file and you are ready to go.

Note: you can run the tests either using CMD+U on Xcode or running fastlane tests via the CLI.

First-party libraries

Lightweight Progress HUD implementation for iOS.

Third-party libraries

Used for downloading and caching images. In the app, it is used to show the poster and backdrop image of the movie.

Custom UICollectionViewLayout to display slanted content. In the app, it is used to present the list of favorite movies.

Helper functions for saving text in Keychain securely for iOS, OS X, tvOS and watchOS. In the app, it is used to save the Session Id and Account Id of the signed in user.

A tool to enforce Swift style and conventions.

Dependency injection framework for Swift.

Contributing

Feel free to open an issue or submit a pull request if you have any improvement or feedback.

Author

Alonso Alvarez, alonso.alvarez.dev@gmail.com