Skip to main content

Custom Loader (Activity Indicator) in Swift

Creating a custom activity indicator in Swift allows you to tailor the appearance and behavior of your loading spinner to fit the style of your app. Here's a step-by-step guide to creating a simple custom activity indicator using UIView Step 1: Create a New Swift File for the Custom Activity Indicator Create a new Swift file and name it  RotatingCirclesView.swift . Add the following code to define a custom UIView subclass for your activity indicator: // //   RotatingCirclesView.swift //   Welcome In // //   Created by Praveen Kumar on 05/09/24. // import UIKit class RotatingCirclesView : UIView {          let circle1 = UIView ( frame : CGRect ( x : 20 , y : 20 , width : 60 , height : 60 ))     let circle2 = UIView ( frame : CGRect ( x : 120 , y : 20 , width : 60 , height : 60 ))          let position : [ CGRect ] = [ CGRect ( x : 30 , y : 20 , width : 60 , height : 60 ), CGRect ( x : 60 , y : 15 ,...

Dependency Injection swift with constructor injection or property injection

Dependency Injection 

Depandency Injection

Dependency injection in swift is a design pattern achieved by designing your code in a way that your objects or functions receive objects that they depend on, instead of creating their own and avoid loosely coupled 

We are going to explore Example such as 

1. Constructor injection 

2. Property injection 

These two are the types of dependency injection that are used most of the time in swift programming language and if you use them during ios development your code program will have no hidden dependency. This swift Example has easy to understand dependency injection concept. 

This Example Class Event has Hidden Dependency of HttpClient Create in function object internal. Only getEventRecord function have know Dependency HttpClient. let client: HttpClient  = HttpClient() is a hidden Dependency

        

        import Foundation

        import UIKit

        import PlaygroundSupport


        PlaygroundPage.current.needsIndefiniteExecution = true


        //MARK: - Depandency Injection


        struct ApiUrl {

            static let getUrl = "https://reqres.in/api/users?page=2"

        }


        class HttpClient {

            func getDataResponse(urlURLcompletionHandler@escaping(_ dataData?) -> Void){

                URLSession.shared.dataTask(with: url) { dataResponse, urlResponse, error in

                    completionHandler(dataResponse)

                }.resume()

            }

        }


        class Event {

            func getEventRecord(){


                let client: HttpClient  = HttpClient() //Loose coupling


                client.getDataResponse(url: URL(string: ApiUrl.getUrl)!) { responseData in

                    if responseData?.count != 0{

                        print("Response Data ===>  \(responseData?.count ?? 0)")

                    }

                }

            }

        }

            

        let event = Event()

        event.getEventRecord()


        //MARK: -  Output With out Depandency Injection with //Loose coupling

        //Response Data ===>  1030




1 Dependency Injection Property injection 

Now Change With class property of HttpClient is option

        

            class Event {

            var client: HttpClient? = nil

            func getEventRecord(){

                client?.getDataResponse(url: URL(string: ApiUrl.getUrl)!) { responseData in

                    if responseData?.count != 0{

                        print("Response Data ===>  \(responseData?.count ?? 0)")

                    }

                }

            }

        }

            

        let event = Event()

        event.client = HttpClient()

        event.getEventRecord()



1 Dependency Injection Constructor injection 

Now Change With Class Event Constructor init of HttpClient 

        

class Event {

            var client: HttpClient? = nil

            init(_ client: HttpClient){

                self.client = client

            }

            func getEventRecord(){

                client?.getDataResponse(url: URL(string: ApiUrl.getUrl)!) { responseData in

                    if responseData?.count != 0{

                        print("Response Data ===>  \(responseData?.count ?? 0)")

                    }

                }

            }

        }

            

       let event = Event(HttpClient())

       event.getEventRecord()











Comments