Skip to content

Latest commit

 

History

History
67 lines (53 loc) · 3.7 KB

README.md

File metadata and controls

67 lines (53 loc) · 3.7 KB

OpenJobs

Requirements:

  • iOS 13.0+
  • Xcode 11.6
  • Swift 5.2

Objective:

This sample app to demonstrate some aspect of clean architecture using MVVM pattern, RxSwift, dependency injection, SOLID principles , loose coupling, unit testing and some of the best practices used in modern iOS programming using Swift.

App Goal:

  • This project was intended to work as a Job information demo projects for iOS using Swift.
  • The demo uses the Jobs API which returns information in a JSON format.
  • Use of UITableViewController to display Jobs information.
  • Implemented Unit test for business logic
  • Persistent data using Core Data
  • Use of RxSwift for Reactive programming.

Installation

  • Xcode 11.6(required)

  • Clean /DerivedData folder if any

  • Run setup script file

    • ./setup.sh
  • Or if you prefer follow following step

    • pod install pod install
    • Run Cuckoo script to Mock your Swift objects ./Cuckoo-GeneratedMocks.sh
    • Run SwiftGen script to generator Swift code for assets, Localizable.strings etc ./generate-swiftgen.sh
  • Then clean and build the project in Xcode

3rd Party Libraries

Design patterns:

MVVM:

  • MVVM - My preferred architecture.
    • MVVM stands for “Model View ViewModel”
    • It’s a software architecture often used by Apple developers to replace MVC. Model-View-ViewModel (MVVM) is a structural design pattern that separates objects into three distinct groups:
  • Models hold application data. They’re usually structs or simple classes.
  • Views display visual elements and controls on the screen. They’re typically - subclasses of UIView.
  • View models transform model information into values that can be displayed on a view. They’re usually classes, so they can be passed around as references.

Alt text

Screenshot:

  • The first tab is the Open Jobs tab, which contains all Open Jobs.
  • The second tab is the Closed Jobs tab, which contains all Closed Jobs.

Screen Shot 1

Screen Shot 2

App Demo